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

38 lines
1.1 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';
import FontAwesomeIcon from '@fortawesome/react-fontawesome';
import calendarIcon from '@fortawesome/fontawesome-free-regular/faCalendarAlt';
2018-09-08 14:28:40 +03:00
import './DateInput.scss';
2018-07-31 22:24:34 +03:00
export default class DateInput extends React.Component {
constructor(props) {
super(props);
2018-09-08 14:28:40 +03:00
this.inputRef = props.ref || React.createRef();
2018-07-31 22:24:34 +03:00
}
render() {
2018-09-08 14:28:40 +03:00
const { className, isClearable, selected } = this.props;
2018-08-09 21:13:46 +03:00
const showCalendarIcon = !isClearable || isNil(selected);
2018-07-31 22:24:34 +03:00
return (
<div className="date-input-container">
<DatePicker
{...this.props}
2018-09-08 14:28:40 +03:00
className={`date-input-container__input form-control ${className || ''}`}
2018-07-31 22:24:34 +03:00
dateFormat="YYYY-MM-DD"
readOnly
ref={this.inputRef}
/>
2018-08-12 10:01:11 +03:00
{showCalendarIcon && (
<FontAwesomeIcon
icon={calendarIcon}
className="date-input-container__icon"
onClick={() => this.inputRef.current.input.focus()}
/>
)}
2018-07-31 22:24:34 +03:00
</div>
);
}
}