bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/chat/container.jsx

113 lines
3.2 KiB
React
Raw Normal View History

2016-04-29 03:02:51 +08:00
import React, { Component, PropTypes } from 'react';
2016-06-14 01:00:38 +08:00
import { defineMessages, injectIntl } from 'react-intl';
2016-04-29 03:02:51 +08:00
import { createContainer } from 'meteor/react-meteor-data';
const CHAT_CONFIG = Meteor.settings.public.chat;
const PUBLIC_CHAT_KEY = CHAT_CONFIG.public_id;
2016-07-01 01:10:36 +08:00
2016-05-23 21:09:47 +08:00
import Chat from './component';
2016-06-02 00:33:19 +08:00
import ChatService from './service';
2016-06-14 01:00:38 +08:00
const intlMessages = defineMessages({
titlePublic: {
id: 'app.chat.titlePublic',
defaultMessage: 'Public Chat',
description: 'Public chat title',
},
titlePrivate: {
id: 'app.chat.titlePrivate',
defaultMessage: 'Private Chat with {name}',
description: 'Private chat title',
},
partnerDisconnected: {
id: 'app.chat.partnerDisconnected',
defaultMessage: '{name} has left the meeting',
description: 'System chat message when the private chat partnet disconnect from the meeting',
},
});
2016-04-29 03:02:51 +08:00
class ChatContainer extends Component {
constructor(props) {
super(props);
}
render() {
return (
2016-06-02 00:33:19 +08:00
<Chat {...this.props}>
2016-04-29 03:02:51 +08:00
{this.props.children}
</Chat>
);
}
}
2016-06-14 01:00:38 +08:00
export default injectIntl(createContainer(({ params, intl }) => {
2016-06-02 00:33:19 +08:00
const chatID = params.chatID || PUBLIC_CHAT_KEY;
let messages = [];
2016-06-14 01:00:38 +08:00
let isChatLocked = ChatService.isChatLocked(chatID);
let title = intl.formatMessage(intlMessages.titlePublic);
let chatName = title;
2016-06-02 00:33:19 +08:00
if (chatID === PUBLIC_CHAT_KEY) {
messages = ChatService.getPublicMessages();
} else {
messages = ChatService.getPrivateMessages(chatID);
}
if (messages && chatID !== PUBLIC_CHAT_KEY) {
let userMessage = messages.find(m => m.sender !== null);
let user = ChatService.getUser(chatID, '{{NAME}}');
// TODO: Find out how to get the name of the user when logged out
title = intl.formatMessage(intlMessages.titlePrivate, { name: user.name });
chatName = user.name;
if (user.isLoggedOut) {
let time = Date.now();
let id = `partner-disconnected-${time}`;
let messagePartnerLoggedOut = {
id: id,
content: [{
id: id,
text: intl.formatMessage(intlMessages.partnerDisconnected, { name: user.name }),
time: time,
},],
time: time,
2016-06-14 01:00:38 +08:00
sender: null,
};
messages.push(messagePartnerLoggedOut);
2016-06-14 01:00:38 +08:00
isChatLocked = true;
}
2016-06-02 00:33:19 +08:00
}
2016-07-01 01:10:36 +08:00
const scrollPosition = ChatService.getScrollPosition(chatID);
2016-07-06 00:47:40 +08:00
const hasUnreadMessages = ChatService.hasUnreadMessages(chatID);
2016-07-12 03:42:54 +08:00
const lastReadMessageTime = ChatService.lastReadMessageTime(chatID);
2016-07-01 01:10:36 +08:00
2016-06-02 00:33:19 +08:00
return {
2016-07-01 01:10:36 +08:00
chatID,
chatName,
2016-06-02 00:33:19 +08:00
title,
messages,
2016-07-12 03:42:54 +08:00
lastReadMessageTime,
2016-07-05 02:53:47 +08:00
hasUnreadMessages,
2016-06-07 22:19:19 +08:00
isChatLocked,
2016-07-01 01:10:36 +08:00
scrollPosition,
2016-06-03 02:40:27 +08:00
actions: {
handleClosePrivateChat: chatID => ChatService.closePrivateChat(chatID),
2016-07-01 01:10:36 +08:00
handleSendMessage: message => {
2016-07-06 00:47:40 +08:00
let sentMessage = ChatService.sendMessage(chatID, message);
2016-07-11 20:34:58 +08:00
ChatService.updateScrollPosition(chatID, null); //null so its scrolls to bottom
2016-07-07 20:50:32 +08:00
// ChatService.updateUnreadMessage(chatID, sentMessage.from_time);
2016-07-01 01:10:36 +08:00
},
handleScrollUpdate: position => ChatService.updateScrollPosition(chatID, position),
2016-07-05 02:53:47 +08:00
handleReadMessage: timestamp => ChatService.updateUnreadMessage(chatID, timestamp),
2016-06-03 02:40:27 +08:00
},
2016-06-02 00:33:19 +08:00
};
2016-06-14 01:00:38 +08:00
}, ChatContainer));