2023-02-06 10:01:03 -08:00
|
|
|
import clsx from 'clsx';
|
2022-05-23 12:14:42 -07:00
|
|
|
import React from 'react';
|
|
|
|
|
2022-12-25 15:52:06 -08:00
|
|
|
import Account from 'soapbox/components/account';
|
2022-05-23 12:14:42 -07:00
|
|
|
import AttachmentThumbs from 'soapbox/components/attachment-thumbs';
|
2022-11-15 08:00:49 -08:00
|
|
|
import StatusContent from 'soapbox/components/status-content';
|
2022-11-15 11:00:40 -08:00
|
|
|
import StatusReplyMentions from 'soapbox/components/status-reply-mentions';
|
2022-05-23 12:14:42 -07:00
|
|
|
import { HStack } from 'soapbox/components/ui';
|
2022-11-16 05:32:32 -08:00
|
|
|
import PollPreview from 'soapbox/features/ui/components/poll-preview';
|
2022-05-23 12:14:42 -07:00
|
|
|
import { useAppSelector } from 'soapbox/hooks';
|
|
|
|
|
|
|
|
import { buildStatus } from '../builder';
|
|
|
|
|
2022-11-15 11:00:40 -08:00
|
|
|
import ScheduledStatusActionBar from './scheduled-status-action-bar';
|
2022-05-23 12:14:42 -07:00
|
|
|
|
2022-06-16 08:47:57 -07:00
|
|
|
import type { Account as AccountEntity, Status as StatusEntity } from 'soapbox/types/entities';
|
2022-05-23 12:14:42 -07:00
|
|
|
|
|
|
|
interface IScheduledStatus {
|
2023-02-15 13:26:27 -08:00
|
|
|
statusId: string
|
2022-05-23 12:14:42 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const ScheduledStatus: React.FC<IScheduledStatus> = ({ statusId, ...other }) => {
|
2023-01-01 14:21:05 -08:00
|
|
|
const status = useAppSelector((state) => {
|
|
|
|
const scheduledStatus = state.scheduled_statuses.get(statusId);
|
|
|
|
if (!scheduledStatus) return null;
|
|
|
|
return buildStatus(state, scheduledStatus);
|
|
|
|
}) as StatusEntity | null;
|
2022-05-23 12:14:42 -07:00
|
|
|
|
|
|
|
if (!status) return null;
|
|
|
|
|
|
|
|
const account = status.account as AccountEntity;
|
|
|
|
|
|
|
|
return (
|
2023-02-06 10:01:03 -08:00
|
|
|
<div className={clsx('status__wrapper', `status__wrapper-${status.visibility}`, { 'status__wrapper-reply': !!status.in_reply_to_id })} tabIndex={0}>
|
|
|
|
<div className={clsx('status', `status-${status.visibility}`, { 'status-reply': !!status.in_reply_to_id })} data-id={status.id}>
|
2022-05-23 12:14:42 -07:00
|
|
|
<div className='mb-4'>
|
|
|
|
<HStack justifyContent='between' alignItems='start'>
|
2022-12-25 15:52:06 -08:00
|
|
|
<Account
|
2022-05-23 12:14:42 -07:00
|
|
|
key={account.id}
|
2022-12-25 15:52:06 -08:00
|
|
|
account={account}
|
2022-05-23 12:14:42 -07:00
|
|
|
timestamp={status.created_at}
|
|
|
|
futureTimestamp
|
2022-12-30 13:43:58 -08:00
|
|
|
hideActions
|
2022-05-23 12:14:42 -07:00
|
|
|
/>
|
|
|
|
</HStack>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<StatusReplyMentions status={status} />
|
|
|
|
|
|
|
|
<StatusContent
|
|
|
|
status={status}
|
|
|
|
collapsable
|
|
|
|
/>
|
|
|
|
|
|
|
|
{status.media_attachments.size > 0 && (
|
|
|
|
<AttachmentThumbs
|
|
|
|
media={status.media_attachments}
|
|
|
|
sensitive={status.sensitive}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
|
2022-06-16 08:08:57 -07:00
|
|
|
{status.poll && <PollPreview pollId={status.poll as string} />}
|
2022-05-23 12:14:42 -07:00
|
|
|
|
|
|
|
<ScheduledStatusActionBar status={status} {...other} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default ScheduledStatus;
|