import React from 'react'; import PropTypes from 'prop-types'; import { View, Text, ScrollView } from 'react-native'; import { connect } from 'react-redux'; import moment from 'moment'; import SafeAreaView from 'react-native-safe-area-view'; import equal from 'deep-equal'; import Navigation from '../../lib/Navigation'; import LoggedView from '../View'; import Status from '../../containers/status'; import Avatar from '../../containers/Avatar'; import styles from './styles'; import sharedStyles from '../Styles'; import database from '../../lib/realm'; import RocketChat from '../../lib/rocketchat'; import log from '../../utils/log'; import RoomTypeIcon from '../../containers/RoomTypeIcon'; import I18n from '../../i18n'; import Icons from '../../lib/Icons'; const PERMISSION_EDIT_ROOM = 'edit-room'; const camelize = str => str.replace(/^(.)/, (match, chr) => chr.toUpperCase()); const getRoomTitle = room => (room.t === 'd' ? {room.fname} : ( {room.name} ) ); @connect(state => ({ baseUrl: state.settings.Site_Url || state.server ? state.server.server : '', user: { id: state.login.user && state.login.user.id, token: state.login.user && state.login.user.token }, activeUsers: state.activeUsers, // TODO: remove it Message_TimeFormat: state.settings.Message_TimeFormat, allRoles: state.roles, room: state.room })) /** @extends React.Component */ export default class RoomInfoView extends LoggedView { static options() { return { topBar: { title: { text: I18n.t('Room_Info') } } }; } static propTypes = { componentId: PropTypes.string, rid: PropTypes.string, user: PropTypes.shape({ id: PropTypes.string, token: PropTypes.string }), baseUrl: PropTypes.string, activeUsers: PropTypes.object, Message_TimeFormat: PropTypes.string, allRoles: PropTypes.object, room: PropTypes.object } constructor(props) { super('RoomInfoView', props); const { rid, room } = props; this.rooms = database.objects('subscriptions').filtered('rid = $0', rid); this.sub = { unsubscribe: () => {} }; this.state = { room, roomUser: {}, roles: [] }; Navigation.events().bindComponent(this); } async componentDidMount() { this.rooms.addListener(this.updateRoom); let room = {}; if (this.rooms.length > 0) { room = this.rooms[0]; // eslint-disable-line prefer-destructuring } else { room = this.state.room; // eslint-disable-line } const { componentId } = this.props; const permissions = RocketChat.hasPermission([PERMISSION_EDIT_ROOM], room.rid); if (permissions[PERMISSION_EDIT_ROOM]) { Navigation.mergeOptions(componentId, { topBar: { rightButtons: [{ id: 'edit', icon: Icons.getSource('create', false), testID: 'room-info-view-edit-button' }] } }); } // get user of room if (room) { if (room.t === 'd') { try { const { user, activeUsers } = this.props; const roomUser = await RocketChat.getRoomMember(room.rid, user.id); this.setState({ roomUser: roomUser || {} }); const username = room.name; const activeUser = activeUsers[roomUser._id]; if (!activeUser || !activeUser.utcOffset) { // get full user data looking for utcOffset // will be catched by .on('users) and saved on activeUsers reducer this.getFullUserData(username); } // get all users roles // needs to be changed by a better method const allUsersRoles = await RocketChat.getUserRoles(); const userRoles = allUsersRoles.find(u => u.username === username); if (userRoles) { this.setState({ roles: userRoles.roles || [] }); } } catch (e) { log('RoomInfoView.componentDidMount', e); } } } } shouldComponentUpdate(nextProps, nextState) { const { room, roomUser, roles } = this.state; const { activeUsers } = this.props; if (!equal(nextState.room, room)) { return true; } if (!equal(nextState.roomUser, roomUser)) { return true; } if (!equal(nextState.roles, roles)) { return true; } if (roomUser._id) { if (nextProps.activeUsers[roomUser._id] !== activeUsers[roomUser._id]) { return true; } } return false; } componentWillUnmount() { this.rooms.removeAllListeners(); this.sub.unsubscribe(); } navigationButtonPressed = ({ buttonId }) => { const { rid, componentId } = this.props; if (buttonId === 'edit') { Navigation.push(componentId, { component: { id: 'RoomInfoEditView', name: 'RoomInfoEditView', passProps: { rid } } }); } } getFullUserData = async(username) => { try { const result = await RocketChat.subscribe('fullUserData', username); this.sub = result; } catch (e) { log('getFullUserData', e); } } isDirect = () => { const { room: { t } } = this.state; return t === 'd'; } updateRoom = () => { if (this.rooms.length > 0) { this.setState({ room: JSON.parse(JSON.stringify(this.rooms[0])) }); } } renderItem = (key, room) => ( {I18n.t(camelize(key))} { room[key] ? room[key] : I18n.t(`No_${ key }_provided`) } ); renderRoles = () => { const { roles } = this.state; const { allRoles } = this.props; return ( roles.length > 0 ? ( {I18n.t('Roles')} {roles.map(role => ( { allRoles[role] } ))} ) : null ); } renderTimezone = (userId) => { const { activeUsers, Message_TimeFormat } = this.props; if (activeUsers[userId]) { const { utcOffset } = activeUsers[userId]; if (!utcOffset) { return null; } return ( {I18n.t('Timezone')} {moment().utcOffset(utcOffset).format(Message_TimeFormat)} (UTC { utcOffset }) ); } return null; } renderAvatar = (room, roomUser) => { const { baseUrl, user } = this.props; return ( {room.t === 'd' ? : null} ); } renderBroadcast = () => ( {I18n.t('Broadcast_Channel')} {I18n.t('Broadcast_channel_Description')} ) renderCustomFields = (userId) => { const { activeUsers } = this.props; if (activeUsers[userId]) { const { customFields } = activeUsers[userId]; if (!customFields) { return null; } return ( Object.keys(customFields).map((title) => { if (!customFields[title]) { return; } return ( {title} {customFields[title]} ); }) ); } return null; } render() { const { room, roomUser } = this.state; if (!room) { return ; } return ( {this.renderAvatar(room, roomUser)} { getRoomTitle(room) } {!this.isDirect() ? this.renderItem('description', room) : null} {!this.isDirect() ? this.renderItem('topic', room) : null} {!this.isDirect() ? this.renderItem('announcement', room) : null} {this.isDirect() ? this.renderRoles() : null} {this.isDirect() ? this.renderTimezone(roomUser._id) : null} {this.isDirect() ? this.renderCustomFields(roomUser._id) : null} {room.broadcast ? this.renderBroadcast() : null} ); } }