Files
mattermost/web/react/components/team_members.jsx

133 lines
3.9 KiB
React
Raw Normal View History

2015-06-14 23:53:32 -08:00
// Copyright (c) 2015 Spinpunch, Inc. All Rights Reserved.
// See License.txt for license information.
var UserStore = require('../stores/user_store.jsx');
var MemberListTeam = require('./member_list_team.jsx');
var utils = require('../utils/utils.jsx');
function getStateFromStores() {
var users = UserStore.getProfiles();
2015-09-01 17:06:31 -07:00
var memberList = [];
for (var id in users) {
if (users.hasOwnProperty(id)) {
memberList.push(users[id]);
}
}
memberList.sort(function sort(a, b) {
if (a.username < b.username) {
return -1;
}
if (a.username > b.username) {
return 1;
}
2015-06-14 23:53:32 -08:00
return 0;
});
return {
2015-09-01 17:06:31 -07:00
member_list: memberList
2015-06-14 23:53:32 -08:00
};
}
2015-09-01 17:06:31 -07:00
export default class TeamMembers extends React.Component {
constructor(props) {
super(props);
this.onChange = this.onChange.bind(this);
this.state = getStateFromStores();
}
componentDidMount() {
UserStore.addChangeListener(this.onChange);
2015-06-14 23:53:32 -08:00
var self = this;
$(React.findDOMNode(this.refs.modal)).on('hidden.bs.modal', function show() {
2015-09-01 17:06:31 -07:00
self.setState({render_members: false});
2015-06-14 23:53:32 -08:00
});
2015-09-02 13:06:56 -07:00
$(React.findDOMNode(this.refs.modal)).on('show.bs.modal', function hide() {
2015-09-01 17:06:31 -07:00
self.setState({render_members: true});
2015-06-14 23:53:32 -08:00
});
2015-09-01 17:06:31 -07:00
}
componentWillUnmount() {
UserStore.removeChangeListener(this.onChange);
}
onChange() {
2015-06-14 23:53:32 -08:00
var newState = getStateFromStores();
if (!utils.areStatesEqual(newState, this.state)) {
this.setState(newState);
}
2015-09-01 17:06:31 -07:00
}
render() {
var serverError = null;
if (this.state.server_error) {
serverError = <label className='has-error control-label'>{this.state.server_error}</label>;
}
var renderMembers = '';
if (this.state.render_members) {
renderMembers = <MemberListTeam users={this.state.member_list} />;
}
2015-06-14 23:53:32 -08:00
return (
2015-09-01 17:06:31 -07:00
<div
className='modal fade'
ref='modal'
id='team_members'
tabIndex='-1'
role='dialog'
aria-hidden='true'
>
<div className='modal-dialog'>
<div className='modal-content'>
<div className='modal-header'>
<button
type='button'
className='close'
data-dismiss='modal'
aria-label='Close'
>
<span aria-hidden='true'>×</span>
</button>
<h4
className='modal-title'
id='myModalLabel'
>{this.props.teamDisplayName + ' Members'}</h4>
</div>
<div
ref='modalBody'
className='modal-body'
>
<div className='channel-settings'>
<div className='team-member-list'>
{renderMembers}
</div>
{serverError}
2015-06-14 23:53:32 -08:00
</div>
2015-09-01 17:06:31 -07:00
</div>
<div className='modal-footer'>
<button
type='button'
className='btn btn-default'
data-dismiss='modal'
>Close</button>
2015-06-14 23:53:32 -08:00
</div>
</div>
</div>
</div>
);
}
2015-09-01 17:06:31 -07:00
}
TeamMembers.propTypes = {
teamDisplayName: React.PropTypes.string
};