2022-08-26 09:21:41 +03:00
|
|
|
import { Component } from 'react';
|
2025-05-21 19:52:41 +03:00
|
|
|
import { ReactReduxContext } from 'react-redux';
|
2019-05-04 14:37:30 -07:00
|
|
|
|
2023-07-12 15:51:38 +03:00
|
|
|
import { IMessage } from '../types';
|
2019-05-04 14:37:30 -07:00
|
|
|
|
2022-10-20 12:11:27 +03:00
|
|
|
export interface IProps {
|
2019-05-04 14:37:30 -07:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* The messages array to render.
|
|
|
|
|
*/
|
2022-09-08 12:52:36 +03:00
|
|
|
messages: IMessage[];
|
2019-05-04 14:37:30 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Abstract component to display a list of chat messages, grouped by sender.
|
|
|
|
|
*
|
2021-11-04 22:10:43 +01:00
|
|
|
* @augments PureComponent
|
2019-05-04 14:37:30 -07:00
|
|
|
*/
|
2022-10-20 12:11:27 +03:00
|
|
|
export default class AbstractMessageContainer<P extends IProps, S> extends Component<P, S> {
|
2025-05-21 19:52:41 +03:00
|
|
|
static override contextType = ReactReduxContext;
|
|
|
|
|
declare context: React.ContextType<typeof ReactReduxContext>;
|
|
|
|
|
|
2019-05-04 14:37:30 -07:00
|
|
|
static defaultProps = {
|
2022-08-26 09:21:41 +03:00
|
|
|
messages: [] as IMessage[]
|
2019-05-04 14:37:30 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Iterates over all the messages and creates nested arrays which hold
|
|
|
|
|
* consecutive messages sent by the same participant.
|
|
|
|
|
*
|
|
|
|
|
* @private
|
|
|
|
|
* @returns {Array<Array<Object>>}
|
|
|
|
|
*/
|
|
|
|
|
_getMessagesGroupedBySender() {
|
|
|
|
|
const messagesCount = this.props.messages.length;
|
2022-08-26 09:21:41 +03:00
|
|
|
const groups: IMessage[][] = [];
|
|
|
|
|
let currentGrouping: IMessage[] = [];
|
2019-05-04 14:37:30 -07:00
|
|
|
let currentGroupParticipantId;
|
|
|
|
|
|
2025-05-21 19:52:41 +03:00
|
|
|
const { store } = this.context;
|
|
|
|
|
const state = store.getState();
|
|
|
|
|
const { disableReactionsInChat } = state['features/base/config'];
|
|
|
|
|
|
2019-05-04 14:37:30 -07:00
|
|
|
for (let i = 0; i < messagesCount; i++) {
|
|
|
|
|
const message = this.props.messages[i];
|
|
|
|
|
|
2025-05-21 19:52:41 +03:00
|
|
|
if (message.isReaction && disableReactionsInChat) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2024-08-06 09:30:37 -04:00
|
|
|
if (message.participantId === currentGroupParticipantId) {
|
2019-05-04 14:37:30 -07:00
|
|
|
currentGrouping.push(message);
|
|
|
|
|
} else {
|
2019-05-06 11:21:41 -07:00
|
|
|
currentGrouping.length && groups.push(currentGrouping);
|
2019-05-04 14:37:30 -07:00
|
|
|
|
|
|
|
|
currentGrouping = [ message ];
|
2024-08-06 09:30:37 -04:00
|
|
|
currentGroupParticipantId = message.participantId;
|
2019-05-04 14:37:30 -07:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2019-11-21 15:26:57 +01:00
|
|
|
currentGrouping.length && groups.push(currentGrouping);
|
2019-05-04 14:37:30 -07:00
|
|
|
|
|
|
|
|
return groups;
|
|
|
|
|
}
|
|
|
|
|
}
|