mirror of
https://gitcode.com/GitHub_Trending/ji/jitsi-meet.git
synced 2025-12-30 11:22:31 +00:00
101 lines
2.9 KiB
TypeScript
101 lines
2.9 KiB
TypeScript
import React from 'react';
|
|
import { FlatList, Text, TextStyle, View, ViewStyle } from 'react-native';
|
|
import { connect } from 'react-redux';
|
|
|
|
import { translate } from '../../../base/i18n/functions';
|
|
import { IMessage } from '../../types';
|
|
import AbstractMessageContainer, { IProps as AbstractProps } from '../AbstractMessageContainer';
|
|
|
|
import ChatMessageGroup from './ChatMessageGroup';
|
|
import styles from './styles';
|
|
|
|
interface IProps extends AbstractProps {
|
|
|
|
/**
|
|
* Function to be used to translate i18n labels.
|
|
*/
|
|
t: Function;
|
|
}
|
|
|
|
/**
|
|
* Implements a container to render all the chat messages in a conference.
|
|
*/
|
|
class MessageContainer extends AbstractMessageContainer<IProps, any> {
|
|
/**
|
|
* Instantiates a new instance of the component.
|
|
*
|
|
* @inheritdoc
|
|
*/
|
|
constructor(props: IProps) {
|
|
super(props);
|
|
|
|
this._keyExtractor = this._keyExtractor.bind(this);
|
|
this._renderListEmptyComponent = this._renderListEmptyComponent.bind(this);
|
|
this._renderMessageGroup = this._renderMessageGroup.bind(this);
|
|
}
|
|
|
|
/**
|
|
* Implements {@code Component#render}.
|
|
*
|
|
* @inheritdoc
|
|
*/
|
|
render() {
|
|
const data = this._getMessagesGroupedBySender();
|
|
|
|
return (
|
|
<FlatList
|
|
ListEmptyComponent = { this._renderListEmptyComponent }
|
|
bounces = { false }
|
|
data = { data }
|
|
|
|
// Workaround for RN bug:
|
|
// https://github.com/facebook/react-native/issues/21196
|
|
inverted = { Boolean(data.length) }
|
|
keyExtractor = { this._keyExtractor }
|
|
keyboardShouldPersistTaps = 'handled'
|
|
renderItem = { this._renderMessageGroup } />
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Key extractor for the flatlist.
|
|
*
|
|
* @param {Object} _item - The flatlist item that we need the key to be
|
|
* generated for.
|
|
* @param {number} index - The index of the element.
|
|
* @returns {string}
|
|
*/
|
|
_keyExtractor(_item: Object, index: number) {
|
|
return `key_${index}`;
|
|
}
|
|
|
|
/**
|
|
* Renders a message when there are no messages in the chat yet.
|
|
*
|
|
* @returns {React$Element<any>}
|
|
*/
|
|
_renderListEmptyComponent() {
|
|
const { t } = this.props;
|
|
|
|
return (
|
|
<View style = { styles.emptyComponentWrapper as ViewStyle }>
|
|
<Text style = { styles.emptyComponentText as TextStyle }>
|
|
{ t('chat.noMessagesMessage') }
|
|
</Text>
|
|
</View>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Renders a single chat message.
|
|
*
|
|
* @param {Array<Object>} messages - The chat message to render.
|
|
* @returns {React$Element<*>}
|
|
*/
|
|
_renderMessageGroup({ item: messages }: { item: IMessage[]; }) {
|
|
return <ChatMessageGroup messages = { messages } />;
|
|
}
|
|
}
|
|
|
|
export default translate(connect()(MessageContainer));
|