import React from 'react'; import PropTypes from 'prop-types'; import classNames from 'classnames'; import { useTranslation } from 'react-i18next'; import styles from './DueDate.module.css'; const SIZES = { TINY: 'tiny', SMALL: 'small', MEDIUM: 'medium', }; // TODO: move to styles const STYLES = { tiny: { fontSize: '12px', lineHeight: '20px', padding: '0px 6px', }, small: { fontSize: '12px', lineHeight: '20px', padding: '2px 6px', }, medium: { lineHeight: '20px', padding: '6px 12px', }, }; const FORMATS = { tiny: 'longDate', small: 'longDate', medium: 'longDateTime', }; const DueDate = React.memo(({ value, size, isDisabled, onClick }) => { const [t] = useTranslation(); const style = { ...STYLES[size], }; const contentNode = ( {t(`format:${FORMATS[size]}`, { value, postProcess: 'formatDate', })} ); return onClick ? ( ) : ( contentNode ); }); DueDate.propTypes = { value: PropTypes.instanceOf(Date).isRequired, size: PropTypes.oneOf(Object.values(SIZES)), isDisabled: PropTypes.bool, onClick: PropTypes.func, }; DueDate.defaultProps = { size: SIZES.MEDIUM, isDisabled: false, onClick: undefined, }; export default DueDate;