bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/user-list/container.jsx

86 lines
2.5 KiB
React
Raw Normal View History

2017-07-12 21:18:26 +08:00
import React from 'react';
2017-12-07 00:53:16 +08:00
import PropTypes from 'prop-types';
import { withTracker } from 'meteor/react-meteor-data';
2017-03-16 00:21:26 +08:00
import { meetingIsBreakout } from '/imports/ui/components/app/service';
import Meetings from '/imports/api/meetings';
2017-07-12 21:18:26 +08:00
import Service from './service';
import UserList from './component';
2016-05-20 02:22:56 +08:00
2017-12-07 00:53:16 +08:00
const propTypes = {
openChats: PropTypes.arrayOf(String).isRequired,
users: PropTypes.arrayOf(Object).isRequired,
currentUser: PropTypes.shape({}).isRequired,
meeting: PropTypes.shape({}).isRequired,
isBreakoutRoom: PropTypes.bool.isRequired,
getAvailableActions: PropTypes.func.isRequired,
normalizeEmojiName: PropTypes.func.isRequired,
isMeetingLocked: PropTypes.func.isRequired,
isPublicChat: PropTypes.func.isRequired,
setEmojiStatus: PropTypes.func.isRequired,
assignPresenter: PropTypes.func.isRequired,
removeUser: PropTypes.func.isRequired,
2017-12-07 00:53:16 +08:00
toggleVoice: PropTypes.func.isRequired,
changeRole: PropTypes.func.isRequired,
roving: PropTypes.func.isRequired,
};
2017-07-12 21:18:26 +08:00
const UserListContainer = (props) => {
const {
users,
currentUser,
openChats,
isBreakoutRoom,
meeting,
2017-08-16 22:56:31 +08:00
getAvailableActions,
normalizeEmojiName,
isMeetingLocked,
isPublicChat,
setEmojiStatus,
assignPresenter,
removeUser,
toggleVoice,
changeRole,
roving,
2017-12-07 00:53:16 +08:00
} = props;
2016-05-20 02:22:56 +08:00
2017-07-12 21:18:26 +08:00
return (
<UserList
users={users}
meeting={meeting}
currentUser={currentUser}
openChats={openChats}
isBreakoutRoom={isBreakoutRoom}
setEmojiStatus={setEmojiStatus}
assignPresenter={assignPresenter}
removeUser={removeUser}
toggleVoice={toggleVoice}
changeRole={changeRole}
2017-08-16 22:56:31 +08:00
getAvailableActions={getAvailableActions}
normalizeEmojiName={normalizeEmojiName}
isMeetingLocked={isMeetingLocked}
isPublicChat={isPublicChat}
roving={roving}
2017-12-15 01:31:05 +08:00
/>
2017-07-12 21:18:26 +08:00
);
};
2016-05-20 02:22:56 +08:00
2017-12-07 00:53:16 +08:00
UserListContainer.propTypes = propTypes;
export default withTracker(({ params }) => ({
2016-06-07 00:45:30 +08:00
users: Service.getUsers(),
meeting: Meetings.findOne({}),
2016-06-28 21:10:20 +08:00
currentUser: Service.getCurrentUser(),
2016-06-30 22:45:19 +08:00
openChats: Service.getOpenChats(params.chatID),
2017-03-16 02:03:58 +08:00
isBreakoutRoom: meetingIsBreakout(),
2017-08-16 22:56:31 +08:00
getAvailableActions: Service.getAvailableActions,
normalizeEmojiName: Service.normalizeEmojiName,
2017-09-07 02:32:29 +08:00
isMeetingLocked: Service.isMeetingLocked,
isPublicChat: Service.isPublicChat,
setEmojiStatus: Service.setEmojiStatus,
assignPresenter: Service.assignPresenter,
removeUser: Service.removeUser,
toggleVoice: Service.toggleVoice,
changeRole: Service.changeRole,
roving: Service.roving,
}))(UserListContainer);