import { DefaultTheme } from 'styled-components'; import _ from 'underscore'; import { v4 as uuidv4 } from 'uuid'; import { QuotedAttachmentType } from '../components/conversation/Quote'; import { AttachmentType } from '../types/Attachment'; import { Contact } from '../types/Contact'; import { ConversationTypeEnum } from './conversation'; export type MessageModelType = 'incoming' | 'outgoing'; export type MessageDeliveryStatus = 'sending' | 'sent' | 'delivered' | 'read' | 'error'; export interface MessageAttributes { // the id of the message // this can have several uses: id: string; source: string; quote?: any; expireTimer: number; received_at?: number; sent_at?: number; destination?: string; preview?: any; body?: string; expirationStartTimestamp: number; read_by: Array; delivered_to: Array; decrypted_at: number; expires_at?: number; recipients: Array; delivered?: number; type: MessageModelType; group_update?: any; groupInvitation?: any; attachments?: any; contact?: any; conversationId: string; errors?: any; flags?: number; hasAttachments: boolean; hasFileAttachments: boolean; hasVisualMediaAttachments: boolean; schemaVersion: number; expirationTimerUpdate?: { expireTimer: number; source: string; fromSync?: boolean; }; /** * 1 means unread, 0 or anything else is read. */ unread: number; group?: any; /** * timestamp is the sent_at timestamp, which is the envelope.timestamp */ timestamp?: number; status: MessageDeliveryStatus; dataMessage: any; sent_to: any; sent: boolean; /** * The serverId is the id on the open group server itself. * Each message sent to an open group gets a serverId. * This is not the id for the server, but the id ON the server. * * This field is not set for a message not on an opengroup server. */ serverId?: number; /** * This is the timestamp of that messages as it was saved by the Open group server. * We rely on this one to order Open Group messages. * This field is not set for a message not on an opengroup server. */ serverTimestamp?: number; /** * This field is set to true if the message is for a public server. * This is useful to make the Badge `Public` Appear on a sent message to a server, even if we did not get * the response from the server yet that this message was successfully added. */ isPublic: boolean; /** * sentSync set to true means we just triggered the sync message for this Private Chat message. * We did not yet get the message sent confirmation, it was just added to the Outgoing MessageQueue */ sentSync: boolean; /** * synced set to true means that this message was successfully sent by our current device to our other devices. * It is set to true when the MessageQueue did effectively sent our sync message without errors. */ synced: boolean; sync: boolean; /** * This field is used for search only */ snippet?: any; direction: any; } export interface MessageAttributesOptionals { id?: string; source?: string; quote?: any; expireTimer?: number; received_at?: number; sent_at?: number; destination?: string; preview?: any; body?: string; expirationStartTimestamp?: number; read_by?: Array; delivered_to?: Array; decrypted_at?: number; expires_at?: number; recipients?: Array; delivered?: number; type: MessageModelType; group_update?: any; groupInvitation?: any; attachments?: any; contact?: any; conversationId: string; errors?: any; flags?: number; hasAttachments?: boolean; hasFileAttachments?: boolean; hasVisualMediaAttachments?: boolean; schemaVersion?: number; expirationTimerUpdate?: { expireTimer: number; source: string; fromSync?: boolean; }; unread?: number; group?: any; timestamp?: number; status?: MessageDeliveryStatus; dataMessage?: any; sent_to?: Array; sent?: boolean; serverId?: number; serverTimestamp?: number; isPublic?: boolean; sentSync?: boolean; synced?: boolean; sync?: boolean; snippet?: any; direction?: any; } /** * This function mutates optAttributes * @param optAttributes the entry object attributes to set the defaults to. */ export const fillMessageAttributesWithDefaults = ( optAttributes: MessageAttributesOptionals ): MessageAttributes => { //FIXME to do put the default return _.defaults(optAttributes, { expireTimer: 0, // disabled id: uuidv4(), schemaVersion: window.Signal.Types.Message.CURRENT_SCHEMA_VERSION, unread: 0, // if nothing is set, this message is considered read }); }; export interface MessageRegularProps { disableMenu?: boolean; isDeletable: boolean; isAdmin?: boolean; weAreAdmin?: boolean; text?: string; id: string; collapseMetadata?: boolean; direction: 'incoming' | 'outgoing'; timestamp: number; serverTimestamp?: number; status?: 'sending' | 'sent' | 'delivered' | 'read' | 'error'; // What if changed this over to a single contact like quote, and put the events on it? contact?: Contact & { onSendMessage?: () => void; onClick?: () => void; }; authorName?: string; authorProfileName?: string; /** Note: this should be formatted for display */ authorPhoneNumber: string; conversationType: ConversationTypeEnum; attachments?: Array; quote?: { text: string; attachment?: QuotedAttachmentType; isFromMe: boolean; authorPhoneNumber: string; authorProfileName?: string; authorName?: string; messageId?: string; onClick: (data: any) => void; referencedMessageNotFound: boolean; }; previews: Array; authorAvatarPath?: string; isExpired: boolean; expirationLength?: number; expirationTimestamp?: number; convoId: string; isPublic?: boolean; isOpenGroupV2?: boolean; selected: boolean; isKickedFromGroup: boolean; // whether or not to show check boxes multiSelectMode: boolean; firstMessageOfSeries: boolean; isUnread: boolean; isQuotedMessageToAnimate?: boolean; onClickAttachment?: (attachment: AttachmentType) => void; onClickLinkPreview?: (url: string) => void; onCopyText?: () => void; onSelectMessage: (messageId: string) => void; onReply?: (messagId: number) => void; onRetrySend?: () => void; onDownload?: (attachment: AttachmentType) => void; onDeleteMessage: (messageId: string) => void; onCopyPubKey?: () => void; onBanUser?: () => void; onUnbanUser?: () => void; onShowDetail: () => void; onShowUserDetails: (userPubKey: string) => void; markRead: (readAt: number) => Promise; theme: DefaultTheme; }