import React from 'react'; import PropTypes from 'prop-types'; import classNames from 'classnames'; import { mapToCssModules, tagPropType } from './utils'; const propTypes = { tag: tagPropType, wrapTag: tagPropType, toggle: PropTypes.func, className: PropTypes.string, cssModule: PropTypes.object, children: PropTypes.node, closeAriaLabel: PropTypes.string, charCode: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), close: PropTypes.object, }; const defaultProps = { tag: 'h5', wrapTag: 'div', closeAriaLabel: 'Close', charCode: 215, }; const ModalHeader = (props) => { let closeButton; const { className, cssModule, children, toggle, tag: Tag, wrapTag: WrapTag, closeAriaLabel, charCode, close, ...attributes } = props; const classes = mapToCssModules(classNames( className, 'modal-header' ), cssModule); if (!close && toggle) { const closeIcon = typeof charCode === 'number' ? String.fromCharCode(charCode) : charCode; closeButton = ( ); } return ( {children} {close || closeButton} ); }; ModalHeader.propTypes = propTypes; ModalHeader.defaultProps = defaultProps; export default ModalHeader;