signal-desktop/ts/components/conversation/TimelineItem.tsx

192 lines
5.2 KiB
TypeScript
Raw Normal View History

import React from 'react';
import { LocalizerType } from '../../types/Util';
import {
Message,
Props as AllMessageProps,
PropsActions as MessageActionsType,
PropsData as MessageProps,
} from './Message';
2019-11-07 21:36:16 +00:00
2020-06-04 18:16:19 +00:00
import {
CallingNotification,
PropsData as CallingNotificationProps,
} from './CallingNotification';
2019-11-07 21:36:16 +00:00
import { InlineNotificationWrapper } from './InlineNotificationWrapper';
import {
PropsActions as UnsupportedMessageActionsType,
PropsData as UnsupportedMessageProps,
UnsupportedMessage,
} from './UnsupportedMessage';
import {
PropsData as TimerNotificationProps,
TimerNotification,
} from './TimerNotification';
import {
PropsActions as SafetyNumberActionsType,
PropsData as SafetyNumberNotificationProps,
SafetyNumberNotification,
} from './SafetyNumberNotification';
import {
PropsData as VerificationNotificationProps,
VerificationNotification,
} from './VerificationNotification';
import {
GroupNotification,
PropsData as GroupNotificationProps,
} from './GroupNotification';
import { ResetSessionNotification } from './ResetSessionNotification';
import {
ProfileChangeNotification,
PropsType as ProfileChangeNotificationPropsType,
} from './ProfileChangeNotification';
2020-06-04 18:16:19 +00:00
type CallHistoryType = {
type: 'callHistory';
data: CallingNotificationProps;
};
type LinkNotificationType = {
type: 'linkNotification';
data: null;
};
type MessageType = {
type: 'message';
data: MessageProps;
};
type UnsupportedMessageType = {
type: 'unsupportedMessage';
data: UnsupportedMessageProps;
};
type TimerNotificationType = {
type: 'timerNotification';
data: TimerNotificationProps;
};
type SafetyNumberNotificationType = {
type: 'safetyNumberNotification';
data: SafetyNumberNotificationProps;
};
type VerificationNotificationType = {
type: 'verificationNotification';
data: VerificationNotificationProps;
};
type GroupNotificationType = {
type: 'groupNotification';
data: GroupNotificationProps;
};
type ResetSessionNotificationType = {
type: 'resetSessionNotification';
data: null;
};
type ProfileChangeNotificationType = {
type: 'profileChange';
data: ProfileChangeNotificationPropsType;
};
export type TimelineItemType =
2020-06-04 18:16:19 +00:00
| CallHistoryType
| GroupNotificationType
| LinkNotificationType
| MessageType
| ProfileChangeNotificationType
| ResetSessionNotificationType
| SafetyNumberNotificationType
| TimerNotificationType
| UnsupportedMessageType
| VerificationNotificationType;
2019-11-07 21:36:16 +00:00
type PropsLocalType = {
conversationId: string;
2020-05-27 21:37:06 +00:00
conversationAccepted: boolean;
item?: TimelineItemType;
2019-11-07 21:36:16 +00:00
id: string;
isSelected: boolean;
selectMessage: (messageId: string, conversationId: string) => unknown;
i18n: LocalizerType;
};
2019-11-07 21:36:16 +00:00
type PropsActionsType = MessageActionsType &
UnsupportedMessageActionsType &
SafetyNumberActionsType;
export type PropsType = PropsLocalType &
PropsActionsType &
Pick<AllMessageProps, 'renderEmojiPicker'>;
2019-11-07 21:36:16 +00:00
export class TimelineItem extends React.PureComponent<PropsType> {
public render() {
2019-11-07 21:36:16 +00:00
const {
conversationId,
id,
isSelected,
item,
i18n,
selectMessage,
} = this.props;
if (!item) {
// tslint:disable-next-line:no-console
2019-11-07 21:36:16 +00:00
console.warn(`TimelineItem: item ${id} provided was falsey`);
return null;
}
if (item.type === 'message') {
return <Message {...this.props} {...item.data} i18n={i18n} />;
}
2019-11-07 21:36:16 +00:00
let notification;
if (item.type === 'unsupportedMessage') {
2019-11-07 21:36:16 +00:00
notification = (
<UnsupportedMessage {...this.props} {...item.data} i18n={i18n} />
);
2020-06-04 18:16:19 +00:00
} else if (item.type === 'callHistory') {
notification = <CallingNotification i18n={i18n} {...item.data} />;
} else if (item.type === 'linkNotification') {
notification = (
<div className="module-message-unsynced">
<div className="module-message-unsynced__icon" />
{i18n('messageHistoryUnsynced')}
</div>
);
2019-11-07 21:36:16 +00:00
} else if (item.type === 'timerNotification') {
notification = (
<TimerNotification {...this.props} {...item.data} i18n={i18n} />
);
} else if (item.type === 'safetyNumberNotification') {
notification = (
<SafetyNumberNotification {...this.props} {...item.data} i18n={i18n} />
);
2019-11-07 21:36:16 +00:00
} else if (item.type === 'verificationNotification') {
notification = (
<VerificationNotification {...this.props} {...item.data} i18n={i18n} />
);
2019-11-07 21:36:16 +00:00
} else if (item.type === 'groupNotification') {
notification = (
<GroupNotification {...this.props} {...item.data} i18n={i18n} />
);
} else if (item.type === 'resetSessionNotification') {
notification = (
<ResetSessionNotification {...this.props} {...item.data} i18n={i18n} />
);
} else if (item.type === 'profileChange') {
notification = (
<ProfileChangeNotification {...this.props} {...item.data} i18n={i18n} />
);
2019-11-07 21:36:16 +00:00
} else {
throw new Error('TimelineItem: Unknown type!');
}
2019-11-07 21:36:16 +00:00
return (
<InlineNotificationWrapper
id={id}
conversationId={conversationId}
isSelected={isSelected}
selectMessage={selectMessage}
>
{notification}
</InlineNotificationWrapper>
);
}
}