2022-05-12 06:42:04 -07:00
|
|
|
'use strict';
|
|
|
|
|
2023-02-06 10:01:03 -08:00
|
|
|
import clsx from 'clsx';
|
2022-05-12 06:42:04 -07:00
|
|
|
import React from 'react';
|
|
|
|
import { defineMessages, FormattedMessage, useIntl } from 'react-intl';
|
|
|
|
|
|
|
|
import { setSchedule, removeSchedule } from 'soapbox/actions/compose';
|
2022-11-15 06:11:30 -08:00
|
|
|
import IconButton from 'soapbox/components/icon-button';
|
2022-05-12 06:42:04 -07:00
|
|
|
import { HStack, Stack, Text } from 'soapbox/components/ui';
|
2022-11-16 05:32:32 -08:00
|
|
|
import BundleContainer from 'soapbox/features/ui/containers/bundle-container';
|
2022-05-12 06:42:04 -07:00
|
|
|
import { DatePicker } from 'soapbox/features/ui/util/async-components';
|
2022-09-14 11:01:00 -07:00
|
|
|
import { useAppDispatch, useCompose } from 'soapbox/hooks';
|
2022-05-12 06:42:04 -07:00
|
|
|
|
2022-08-30 13:26:42 -07:00
|
|
|
export const isCurrentOrFutureDate = (date: Date) => {
|
2022-05-12 06:42:04 -07:00
|
|
|
return date && new Date().setHours(0, 0, 0, 0) <= new Date(date).setHours(0, 0, 0, 0);
|
|
|
|
};
|
|
|
|
|
|
|
|
const isFiveMinutesFromNow = (time: Date) => {
|
|
|
|
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();
|
|
|
|
};
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
schedule: { id: 'schedule.post_time', defaultMessage: 'Post Date/Time' },
|
|
|
|
remove: { id: 'schedule.remove', defaultMessage: 'Remove schedule' },
|
|
|
|
});
|
|
|
|
|
2022-09-10 14:52:06 -07:00
|
|
|
export interface IScheduleForm {
|
2023-02-15 13:26:27 -08:00
|
|
|
composeId: string
|
2022-09-10 14:52:06 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const ScheduleForm: React.FC<IScheduleForm> = ({ composeId }) => {
|
2022-05-12 06:42:04 -07:00
|
|
|
const dispatch = useAppDispatch();
|
|
|
|
const intl = useIntl();
|
|
|
|
|
2022-09-14 11:01:00 -07:00
|
|
|
const scheduledAt = useCompose(composeId).schedule;
|
2022-05-12 06:42:04 -07:00
|
|
|
const active = !!scheduledAt;
|
|
|
|
|
|
|
|
const onSchedule = (date: Date) => {
|
2022-09-10 14:52:06 -07:00
|
|
|
dispatch(setSchedule(composeId, date));
|
2022-05-12 06:42:04 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
const handleRemove = (e: React.MouseEvent<HTMLButtonElement>) => {
|
2022-09-10 14:52:06 -07:00
|
|
|
dispatch(removeSchedule(composeId));
|
2022-05-12 06:42:04 -07:00
|
|
|
e.preventDefault();
|
|
|
|
};
|
|
|
|
|
|
|
|
if (!active) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Stack className='mb-2' space={1}>
|
|
|
|
<Text theme='muted'>
|
|
|
|
<FormattedMessage id='datepicker.hint' defaultMessage='Scheduled to post at…' />
|
|
|
|
</Text>
|
|
|
|
<HStack space={2} alignItems='center'>
|
|
|
|
<BundleContainer fetchComponent={DatePicker}>
|
|
|
|
{Component => (<Component
|
|
|
|
selected={scheduledAt}
|
|
|
|
showTimeSelect
|
|
|
|
dateFormat='MMMM d, yyyy h:mm aa'
|
|
|
|
timeIntervals={15}
|
|
|
|
wrapperClassName='react-datepicker-wrapper'
|
|
|
|
onChange={onSchedule}
|
|
|
|
placeholderText={intl.formatMessage(messages.schedule)}
|
|
|
|
filterDate={isCurrentOrFutureDate}
|
|
|
|
filterTime={isFiveMinutesFromNow}
|
2023-02-06 10:01:03 -08:00
|
|
|
className={clsx({
|
2022-05-12 06:42:04 -07:00
|
|
|
'has-error': !isFiveMinutesFromNow(scheduledAt),
|
|
|
|
})}
|
|
|
|
/>)}
|
|
|
|
</BundleContainer>
|
|
|
|
<IconButton
|
2023-02-15 13:26:27 -08:00
|
|
|
iconClassName='h-4 w-4'
|
2022-05-12 06:42:04 -07:00
|
|
|
className='bg-transparent text-gray-400 hover:text-gray-600'
|
2022-07-09 09:20:02 -07:00
|
|
|
src={require('@tabler/icons/x.svg')}
|
2022-05-12 06:42:04 -07:00
|
|
|
onClick={handleRemove}
|
|
|
|
title={intl.formatMessage(messages.remove)}
|
|
|
|
/>
|
|
|
|
</HStack>
|
|
|
|
</Stack>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ScheduleForm;
|