shlink-web-client/src/utils/DateInput.js

43 lines
1.2 KiB
JavaScript
Raw Normal View History

2018-07-31 22:24:34 +03:00
import React from 'react';
2018-08-09 21:13:46 +03:00
import { isNil } from 'ramda';
2018-11-01 11:05:20 +03:00
import DatePicker from 'react-datepicker';
2019-01-06 00:25:54 +03:00
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faCalendarAlt as calendarIcon } from '@fortawesome/free-regular-svg-icons';
import * as PropTypes from 'prop-types';
2018-09-08 14:28:40 +03:00
import './DateInput.scss';
2018-07-31 22:24:34 +03:00
const propTypes = {
className: PropTypes.string,
isClearable: PropTypes.bool,
selected: PropTypes.oneOfType([ PropTypes.string, PropTypes.object ]),
ref: PropTypes.object,
};
2018-07-31 22:24:34 +03:00
const DateInput = (props) => {
const { className, isClearable, selected, ref = React.createRef() } = props;
const showCalendarIcon = !isClearable || isNil(selected);
2018-08-09 21:13:46 +03:00
return (
<div className="date-input-container">
<DatePicker
{...props}
className={`date-input-container__input form-control ${className || ''}`}
dateFormat="YYYY-MM-DD"
readOnly
ref={ref}
/>
{showCalendarIcon && (
<FontAwesomeIcon
icon={calendarIcon}
className="date-input-container__icon"
onClick={() => ref.current.input.focus()}
2018-07-31 22:24:34 +03:00
/>
)}
</div>
);
};
DateInput.propTypes = propTypes;
export default DateInput;