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

155 lines
5.8 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 utils = require('../utils/utils.jsx');
var client = require('../utils/client.jsx');
var UserStore = require('../stores/user_store.jsx');
var TeamStore = require('../stores/team_store.jsx');
2015-06-14 23:53:32 -08:00
2015-07-23 14:59:43 +05:00
var Constants = require('../utils/constants.jsx');
2015-06-14 23:53:32 -08:00
function getStateFromStores() {
return {teams: UserStore.getTeams(), currentTeam: TeamStore.getCurrent()};
2015-06-14 23:53:32 -08:00
}
var NavbarDropdown = React.createClass({
handleLogoutClick: function(e) {
e.preventDefault();
client.logout();
},
blockToggle: false,
2015-06-14 23:53:32 -08:00
componentDidMount: function() {
UserStore.addTeamsChangeListener(this.onListenerChange);
TeamStore.addChangeListener(this.onListenerChange);
var self = this;
$(this.refs.dropdown.getDOMNode()).on('hide.bs.dropdown', function(e) {
self.blockToggle = true;
setTimeout(function(){self.blockToggle = false;}, 100);
});
2015-06-14 23:53:32 -08:00
},
componentWillUnmount: function() {
UserStore.removeTeamsChangeListener(this.onListenerChange);
TeamStore.removeChangeListener(this.onListenerChange);
$(this.refs.dropdown.getDOMNode()).off('hide.bs.dropdown');
2015-06-14 23:53:32 -08:00
},
onListenerChange: function() {
2015-06-14 23:53:32 -08:00
if (this.isMounted()) {
var newState = getStateFromStores();
if (!utils.areStatesEqual(newState, this.state)) {
this.setState(newState);
}
}
},
getInitialState: function() {
return getStateFromStores();
},
render: function() {
var team_link = "";
var invite_link = "";
var manage_link = "";
var rename_link = "";
var currentUser = UserStore.getCurrentUser();
2015-06-14 23:53:32 -08:00
var isAdmin = false;
if (currentUser != null) {
isAdmin = currentUser.roles.indexOf("admin") > -1;
invite_link = ( <li> <a href="#" data-toggle="modal" data-target="#invite_member">Invite New Member</a> </li>);
2015-06-14 23:53:32 -08:00
if (this.props.teamType == "O") {
team_link = (
<li>
<a href="#" data-toggle="modal" data-target="#get_link" data-title="Team Invite" data-value={location.origin+"/signup_user_complete/?id="+currentUser.team_id}>Get Team Invite Link</a>
</li>
);
}
}
if (isAdmin) {
manage_link = ( <li> <a href="#" data-toggle="modal" data-target="#team_members">Manage Team</a> </li>);
rename_link = ( <li> <a href="#" data-toggle="modal" data-target="#rename_team_link">Rename</a> </li>);
2015-06-14 23:53:32 -08:00
}
var teams = [];
teams.push(<li className="divider" key="div"></li>);
if (this.state.teams.length > 1 && this.state.currentTeam) {
var curTeamName = this.state.currentTeam.name;
this.state.teams.forEach(function(teamName) {
if (teamName !== curTeamName) {
teams.push(<li key={ teamName }><a href={utils.getWindowLocationOrigin() + "/" + teamName }>Switch to { teamName }</a></li>);
}
});
2015-06-14 23:53:32 -08:00
}
teams.push(<li><a href={utils.getWindowLocationOrigin() + "/signup_team" }>Create a New Team</a></li>);
2015-06-14 23:53:32 -08:00
return (
<ul className="nav navbar-nav navbar-right">
<li ref="dropdown" className="dropdown">
2015-06-14 23:53:32 -08:00
<a href="#" className="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">
2015-07-23 14:59:43 +05:00
<span className="dropdown__icon" dangerouslySetInnerHTML={{__html: Constants.MENU_ICON }} />
2015-06-14 23:53:32 -08:00
</a>
<ul className="dropdown-menu" role="menu">
<li><a href="#" data-toggle="modal" data-target="#user_settings1">Account Settings</a></li>
{ isAdmin ? <li><a href="#" data-toggle="modal" data-target="#team_settings">Team Settings</a></li> : null }
2015-06-14 23:53:32 -08:00
{ invite_link }
{ team_link }
{ manage_link }
{ rename_link }
<li><a href="#" onClick={this.handleLogoutClick}>Logout</a></li>
{ teams }
<li className="divider"></li>
<li><a target="_blank" href={config.HelpLink}>Help</a></li>
<li><a target="_blank" href={config.ReportProblemLink}>Report a Problem</a></li>
</ul>
</li>
</ul>
);
}
});
module.exports = React.createClass({
displayName: 'SidebarHeader',
getDefaultProps: function() {
return {
2015-07-08 12:51:43 -07:00
teamDisplayName: config.SiteName
};
2015-06-14 23:53:32 -08:00
},
toggleDropdown: function(e) {
if (this.refs.dropdown.blockToggle) {
this.refs.dropdown.blockToggle = false;
return;
}
$('.team__header').find('.dropdown-toggle').dropdown('toggle');
},
2015-06-14 23:53:32 -08:00
render: function() {
2015-07-08 12:51:43 -07:00
var me = UserStore.getCurrentUser();
if (!me) {
return null;
}
2015-06-14 23:53:32 -08:00
return (
<div className="team__header theme">
<a href="#" onClick={this.toggleDropdown}>
{ me.last_picture_update ?
<img className="user__picture" src={"/api/v1/users/" + me.id + "/image?time=" + me.update_at} />
:
2015-07-08 12:51:43 -07:00
null
}
<div className="header__info">
<div className="user__name">{ '@' + me.username}</div>
2015-07-08 12:51:43 -07:00
<div className="team__name">{ this.props.teamDisplayName }</div>
</div>
</a>
<NavbarDropdown ref="dropdown" teamType={this.props.teamType} />
2015-06-14 23:53:32 -08:00
</div>
);
}
});