/* * Copyright © 2016-2018 European Support Limited * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import React from 'react'; import PropTypes from 'prop-types'; import DatePicker from 'react-datepicker'; import moment from 'moment'; import SVGIcon from 'onap-ui-react/lib/components/SVGIcon.js'; class CustomInput extends React.Component { static propTypes = { placeHolderText: PropTypes.string, onChange: PropTypes.func, onClick: PropTypes.func, value: PropTypes.string }; render() { const { placeholderText, onClick, onClear, inputRef, value: date } = this.props; const text = date ? date : placeholderText; const textStyle = date ? '' : 'placeholder'; return ( <div onClick={onClick} ref={inputRef} className="datepicker-custom-input"> <div className={`datepicker-text ${textStyle}`}>{text}</div> {date && ( <SVGIcon onClick={e => { e.stopPropagation(); onClear(); }} name="close" className="clear-input" /> )} <SVGIcon name="calendar" /> </div> ); } } const parseDate = (date, format) => { return typeof date === 'number' ? moment.unix(date) : moment(date, format); }; class Datepicker extends React.Component { static propTypes = { date: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), format: PropTypes.string, onChange: PropTypes.func, selectsStart: PropTypes.bool, selectsEnd: PropTypes.bool, startDate: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), endDate: PropTypes.oneOfType([PropTypes.string, PropTypes.number]), disabled: PropTypes.bool, label: PropTypes.string, isRequired: PropTypes.bool }; render() { let { date, format, onChange, selectsStart = false, startDate = null, endDate = null, selectsEnd = false, disabled = false, inputRef } = this.props; const placeholderText = 'Enter a date'; const props = { format, onChange, disabled, selected: date ? parseDate(date, format) : date, selectsStart, selectsEnd, placeholderText, startDate: startDate ? parseDate(startDate, format) : startDate, endDate: endDate ? parseDate(endDate, format) : endDate }; return ( <div className="customized-date-picker"> <DatePicker calendarClassName="customized-date-picker-calendar" customInput={ <CustomInput inputRef={inputRef} onClear={() => onChange(undefined)} placeholderText={placeholderText} /> } minDate={ selectsEnd && props.startDate ? props.startDate : undefined } maxDate={ selectsStart && props.endDate ? props.endDate : undefined } popperModifiers={{ preventOverflow: { boundariesElement: 'scrollParent' } }} {...props} /> </div> ); } } export default Datepicker;