Add component user-admin/List
Change-Id: I9a02165af1ad83c9ec3727d8e40d64be0a2540d0
This commit is contained in:
parent
0254788901
commit
b44238422a
@ -1,39 +0,0 @@
|
||||
import React, { Component } from 'react';
|
||||
import PropTypes from 'prop-types';
|
||||
import { bindActionCreators } from 'redux';
|
||||
import { connect } from 'react-redux';
|
||||
import * as actions from './redux/actions';
|
||||
|
||||
export class DefaultPage extends Component {
|
||||
static propTypes = {
|
||||
userAdmin: PropTypes.object.isRequired,
|
||||
actions: PropTypes.object.isRequired,
|
||||
};
|
||||
|
||||
render() {
|
||||
return (
|
||||
<div className="user-admin-default-page">
|
||||
Page Content: user-admin/DefaultPage
|
||||
</div>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/* istanbul ignore next */
|
||||
function mapStateToProps(state) {
|
||||
return {
|
||||
userAdmin: state.userAdmin,
|
||||
};
|
||||
}
|
||||
|
||||
/* istanbul ignore next */
|
||||
function mapDispatchToProps(dispatch) {
|
||||
return {
|
||||
actions: bindActionCreators({ ...actions }, dispatch)
|
||||
};
|
||||
}
|
||||
|
||||
export default connect(
|
||||
mapStateToProps,
|
||||
mapDispatchToProps
|
||||
)(DefaultPage);
|
@ -1,5 +0,0 @@
|
||||
@import '../../styles/mixins';
|
||||
|
||||
.user-admin-default-page {
|
||||
|
||||
}
|
69
src/features/user-admin/List.js
Normal file
69
src/features/user-admin/List.js
Normal file
@ -0,0 +1,69 @@
|
||||
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 = {
|
||||
mtx: PropTypes.object.isRequired,
|
||||
userAdmin: PropTypes.object.isRequired,
|
||||
actions: PropTypes.object.isRequired,
|
||||
};
|
||||
|
||||
componentDidMount() {
|
||||
const { fetchUsers } = this.props.actions;
|
||||
fetchUsers();
|
||||
}
|
||||
|
||||
render() {
|
||||
const { mtx } = this.props;
|
||||
const { userList, fetchUsersPending } = this.props.userAdmin;
|
||||
return (
|
||||
<div className="user-admin-list">
|
||||
{(!mtx || !mtx.clientRunning) && <Redirect to="/" />}
|
||||
{fetchUsersPending && <img alt="logging in" src="" />}
|
||||
<Table className="user-list">
|
||||
<TableHead>
|
||||
<TableRow>
|
||||
<TableCell>Username</TableCell>
|
||||
<TableCell>Guest</TableCell>
|
||||
<TableCell>Admin</TableCell>
|
||||
</TableRow>
|
||||
</TableHead>
|
||||
<TableBody>
|
||||
{userList.map(item => (
|
||||
<TableRow key={item.name}>
|
||||
<TableCell>{item.name}</TableCell>
|
||||
<TableCell>{item.is_guest ? 'X' : ''}</TableCell>
|
||||
<TableCell>{item.admin ? 'X' : ''}</TableCell>
|
||||
</TableRow>
|
||||
))}
|
||||
</TableBody>
|
||||
</Table>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
/* istanbul ignore next */
|
||||
function mapStateToProps(state) {
|
||||
return {
|
||||
mtx: state.common.mtx,
|
||||
userAdmin: state.userAdmin,
|
||||
};
|
||||
}
|
||||
|
||||
/* istanbul ignore next */
|
||||
function mapDispatchToProps(dispatch) {
|
||||
return {
|
||||
actions: bindActionCreators({ ...actions }, dispatch),
|
||||
};
|
||||
}
|
||||
|
||||
export default connect(
|
||||
mapStateToProps,
|
||||
mapDispatchToProps
|
||||
)(List);
|
9
src/features/user-admin/List.scss
Normal file
9
src/features/user-admin/List.scss
Normal file
@ -0,0 +1,9 @@
|
||||
@import '../../styles/mixins';
|
||||
|
||||
.user-admin-list {
|
||||
th {
|
||||
background-color: #EEE;
|
||||
font-size: 1rem;
|
||||
font-weight: bold;
|
||||
}
|
||||
}
|
@ -1 +1 @@
|
||||
export { default as DefaultPage } from './DefaultPage';
|
||||
export { default as List } from './List';
|
||||
|
@ -2,7 +2,7 @@
|
||||
// Learn more from: http://rekit.js.org/docs/routing.html
|
||||
|
||||
import {
|
||||
DefaultPage,
|
||||
List,
|
||||
} from './';
|
||||
import { Layout } from '../common';
|
||||
|
||||
@ -11,6 +11,6 @@ export default {
|
||||
name: 'User admin',
|
||||
component: Layout,
|
||||
childRoutes: [
|
||||
{ path: 'default-page', name: 'Default page', component: DefaultPage, isIndex: true },
|
||||
{ path: 'list', name: 'List', component: List, isIndex: true },
|
||||
],
|
||||
};
|
||||
|
@ -1,2 +1,2 @@
|
||||
@import '../../styles/mixins';
|
||||
@import './DefaultPage';
|
||||
@import './List';
|
||||
|
@ -1,19 +1,19 @@
|
||||
import React from 'react';
|
||||
import { shallow } from 'enzyme';
|
||||
import { DefaultPage } from '../../../src/features/user-admin/DefaultPage';
|
||||
import { List } from '../../../src/features/user-admin/List';
|
||||
|
||||
describe('user-admin/DefaultPage', () => {
|
||||
describe('user-admin/List', () => {
|
||||
it('renders node with correct class name', () => {
|
||||
const props = {
|
||||
userAdmin: {},
|
||||
actions: {},
|
||||
};
|
||||
const renderedComponent = shallow(
|
||||
<DefaultPage {...props} />
|
||||
<List {...props} />
|
||||
);
|
||||
|
||||
expect(
|
||||
renderedComponent.find('.user-admin-default-page').length
|
||||
renderedComponent.find('.user-admin-list').length
|
||||
).toBe(1);
|
||||
});
|
||||
});
|
Loading…
Reference in New Issue
Block a user