TelegramPWA/src/components/common/LastMessageMeta.tsx
2024-08-29 15:52:14 +02:00

40 lines
1.1 KiB
TypeScript

import React, { memo } from '../../lib/teact/teact';
import type { ApiMessage, ApiMessageOutgoingStatus } from '../../api/types';
import buildClassName from '../../util/buildClassName';
import { formatPastTimeShort } from '../../util/dates/dateFormat';
import useOldLang from '../../hooks/useOldLang';
import MessageOutgoingStatus from './MessageOutgoingStatus';
import './LastMessageMeta.scss';
type OwnProps = {
className?: string;
message: ApiMessage;
outgoingStatus?: ApiMessageOutgoingStatus;
draftDate?: number;
};
const LastMessageMeta = ({
className, message, outgoingStatus, draftDate,
}: OwnProps) => {
const lang = useOldLang();
const shouldUseDraft = draftDate && draftDate > message.date;
return (
<div className={buildClassName('LastMessageMeta', className)}>
{outgoingStatus && !shouldUseDraft && (
<MessageOutgoingStatus status={outgoingStatus} />
)}
<span className="time">
{formatPastTimeShort(lang, (shouldUseDraft ? draftDate : message.date) * 1000)}
</span>
</div>
);
};
export default memo(LastMessageMeta);