bigbuffet-rw/app/soapbox/features/compose/components/schedule_form.js

126 lines
3.4 KiB
JavaScript
Raw Normal View History

2021-06-18 09:04:31 -07:00
'use strict';
import React from 'react';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import { defineMessages, injectIntl, FormattedMessage } from 'react-intl';
2021-06-18 09:04:31 -07:00
import DatePicker from 'react-datepicker';
import 'react-datepicker/dist/react-datepicker.css';
2021-06-30 12:53:29 -07:00
import classNames from 'classnames';
2022-01-10 14:01:24 -08:00
import IconButton from 'soapbox/components/icon_button';
import { setSchedule, removeSchedule } from '../../../actions/compose';
2021-06-18 09:04:31 -07:00
const messages = defineMessages({
schedule: { id: 'schedule.post_time', defaultMessage: 'Post Date/Time' },
remove: { id: 'schedule.remove', defaultMessage: 'Remove schedule' },
2021-06-18 09:04:31 -07:00
});
2021-09-11 16:00:48 -07:00
const mapStateToProps = state => ({
active: state.getIn(['compose', 'schedule']) ? true : false,
scheduledAt: state.getIn(['compose', 'schedule']),
});
2021-09-11 16:00:48 -07:00
const mapDispatchToProps = dispatch => ({
onSchedule(date) {
dispatch(setSchedule(date));
},
onRemoveSchedule(date) {
dispatch(removeSchedule());
},
});
export default @connect(mapStateToProps, mapDispatchToProps)
@injectIntl
2021-06-18 09:04:31 -07:00
class ScheduleForm extends React.Component {
static propTypes = {
scheduledAt: PropTypes.instanceOf(Date),
2021-06-18 09:04:31 -07:00
intl: PropTypes.object.isRequired,
onSchedule: PropTypes.func.isRequired,
2021-09-11 16:00:48 -07:00
onRemoveSchedule: PropTypes.func.isRequired,
dispatch: PropTypes.func,
2021-06-18 09:04:31 -07:00
active: PropTypes.bool,
};
2021-06-30 19:02:53 -07:00
state = {
initialized: false,
}
setSchedule = date => {
2021-06-18 09:04:31 -07:00
this.props.onSchedule(date);
}
2021-06-30 19:02:53 -07:00
setRef = c => {
this.datePicker = c;
}
2021-06-18 09:04:31 -07:00
2021-06-30 19:02:53 -07:00
openDatePicker = () => {
if (!this.datePicker) return;
this.datePicker.setOpen(true);
2021-06-18 09:04:31 -07:00
}
isCurrentOrFutureDate(date) {
2021-06-18 14:51:14 -07:00
return date && new Date().setHours(0, 0, 0, 0) <= new Date(date).setHours(0, 0, 0, 0);
2021-06-18 09:04:31 -07:00
}
isFiveMinutesFromNow(time) {
2021-06-18 09:04:31 -07:00
const fiveMinutesFromNow = new Date(new Date().getTime() + 300000); // now, plus five minutes (Pleroma won't schedule posts )
const selectedDate = new Date(time);
return fiveMinutesFromNow.getTime() < selectedDate.getTime();
2021-08-03 12:22:51 -07:00
}
2021-06-18 09:04:31 -07:00
handleRemove = e => {
2021-09-11 16:00:48 -07:00
this.props.onRemoveSchedule();
e.preventDefault();
}
2021-06-30 19:02:53 -07:00
initialize = () => {
const { initialized } = this.state;
if (!initialized && this.datePicker) {
this.openDatePicker();
this.setState({ initialized: true });
}
}
componentDidUpdate() {
this.initialize();
}
2021-06-18 09:04:31 -07:00
render() {
if (!this.props.active) {
2021-06-18 09:04:31 -07:00
return null;
}
const { intl, scheduledAt } = this.props;
2021-06-18 09:04:31 -07:00
return (
2021-06-30 12:53:29 -07:00
<div className={classNames('datepicker', { 'datepicker--error': !this.isFiveMinutesFromNow(scheduledAt) })}>
<div className='datepicker__hint'>
<FormattedMessage id='datepicker.hint' defaultMessage='Scheduled to post at…' />
</div>
<div className='datepicker__input'>
<DatePicker
selected={scheduledAt}
showTimeSelect
dateFormat='MMMM d, yyyy h:mm aa'
timeIntervals={15}
wrapperClassName='react-datepicker-wrapper'
onChange={this.setSchedule}
placeholderText={this.props.intl.formatMessage(messages.schedule)}
filterDate={this.isCurrentOrFutureDate}
filterTime={this.isFiveMinutesFromNow}
2021-06-30 19:02:53 -07:00
ref={this.setRef}
/>
<div className='datepicker__cancel'>
<IconButton title={intl.formatMessage(messages.remove)} src={require('@tabler/icons/icons/x.svg')} onClick={this.handleRemove} />
</div>
</div>
</div>
2021-06-18 09:04:31 -07:00
);
}
}