72 lines
2.9 KiB
JavaScript
72 lines
2.9 KiB
JavaScript
import React, { Component } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import { bindActionCreators } from 'redux';
|
|
import { connect } from 'react-redux';
|
|
import { Redirect } from 'react-router-dom'
|
|
import { Table, TableBody, TableCell, TableHead, TableRow } from '@material-ui/core';
|
|
import * as actions from './redux/actions';
|
|
|
|
export class List extends Component {
|
|
static propTypes = {
|
|
roomAdmin: PropTypes.object.isRequired,
|
|
actions: PropTypes.object.isRequired,
|
|
};
|
|
|
|
componentDidMount() {
|
|
const { fetchPublicRooms } = this.props.actions;
|
|
fetchPublicRooms();
|
|
}
|
|
|
|
render() {
|
|
const { mtx } = this.props;
|
|
const { roomList, fetchRoomsPending } = this.props.roomAdmin;
|
|
|
|
return (
|
|
<div className="room-admin-list">
|
|
{(!mtx || !mtx.clientRunning) && <Redirect to="/" />}
|
|
{fetchRoomsPending && <img alt="logging in" src="" />}
|
|
<Table className="room-list">
|
|
<TableHead>
|
|
<TableRow>
|
|
<TableCell>Alias</TableCell>
|
|
<TableCell>Name</TableCell>
|
|
<TableCell>Topic</TableCell>
|
|
<TableCell>Room-ID</TableCell>
|
|
<TableCell>Members</TableCell>
|
|
</TableRow>
|
|
</TableHead>
|
|
<TableBody>
|
|
{roomList.map(item => (<TableRow key={item.room_id}>
|
|
<TableCell>{item.canonical_alias}</TableCell>
|
|
<TableCell>{item.name}</TableCell>
|
|
<TableCell>{item.topic}</TableCell>
|
|
<TableCell>{item.room_id}</TableCell>
|
|
<TableCell>{item.num_joined_members}</TableCell>
|
|
</TableRow>))}
|
|
</TableBody>
|
|
</Table>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
/* istanbul ignore next */
|
|
function mapStateToProps(state) {
|
|
return {
|
|
mtx: state.common.mtx,
|
|
roomAdmin: state.roomAdmin,
|
|
};
|
|
}
|
|
|
|
/* istanbul ignore next */
|
|
function mapDispatchToProps(dispatch) {
|
|
return {
|
|
actions: bindActionCreators({ ...actions }, dispatch)
|
|
};
|
|
}
|
|
|
|
export default connect(
|
|
mapStateToProps,
|
|
mapDispatchToProps
|
|
)(List);
|