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');
|
|
|
|
|
|
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() };
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var NavbarDropdown = React.createClass({
|
|
|
|
|
handleLogoutClick: function(e) {
|
|
|
|
|
e.preventDefault();
|
|
|
|
|
client.logout();
|
|
|
|
|
},
|
|
|
|
|
componentDidMount: function() {
|
|
|
|
|
UserStore.addTeamsChangeListener(this._onChange);
|
|
|
|
|
},
|
|
|
|
|
componentWillUnmount: function() {
|
|
|
|
|
UserStore.removeTeamsChangeListener(this._onChange);
|
|
|
|
|
},
|
|
|
|
|
_onChange: function() {
|
|
|
|
|
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 = "";
|
2015-07-15 09:03:28 -07:00
|
|
|
var currentUser = UserStore.getCurrentUser();
|
2015-06-14 23:53:32 -08:00
|
|
|
var isAdmin = false;
|
|
|
|
|
|
|
|
|
|
if (currentUser != null) {
|
|
|
|
|
isAdmin = currentUser.roles.indexOf("admin") > -1;
|
|
|
|
|
|
2015-07-15 09:03:28 -07:00
|
|
|
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) {
|
2015-07-15 09:03:28 -07:00
|
|
|
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 = [];
|
|
|
|
|
|
2015-07-08 11:50:10 -04:00
|
|
|
teams.push(<li className="divider" key="div"></li>);
|
2015-06-14 23:53:32 -08:00
|
|
|
if (this.state.teams.length > 1) {
|
|
|
|
|
for (var i = 0; i < this.state.teams.length; i++) {
|
2015-07-08 11:50:10 -04:00
|
|
|
var teamName = this.state.teams[i];
|
2015-06-14 23:53:32 -08:00
|
|
|
|
2015-07-27 13:21:50 -07:00
|
|
|
teams.push(<li key={ teamName }><a href={utils.getWindowLocationOrigin() + "/" + teamName }>Switch to { teamName }</a></li>);
|
2015-06-14 23:53:32 -08:00
|
|
|
}
|
|
|
|
|
}
|
2015-07-27 13:21:50 -07: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">
|
2015-07-29 20:24:28 +05:00
|
|
|
<li 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">
|
2015-06-18 10:40:46 -04:00
|
|
|
<li><a href="#" data-toggle="modal" data-target="#user_settings1">Account Settings</a></li>
|
2015-07-15 09:03:28 -07:00
|
|
|
{ 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({
|
2015-07-15 09:03:28 -07:00
|
|
|
displayName: 'SidebarHeader',
|
|
|
|
|
|
|
|
|
|
getDefaultProps: function() {
|
|
|
|
|
return {
|
2015-07-08 12:51:43 -07:00
|
|
|
teamDisplayName: config.SiteName
|
2015-07-15 09:03:28 -07:00
|
|
|
};
|
2015-06-14 23:53:32 -08:00
|
|
|
},
|
2015-07-15 09:03:28 -07:00
|
|
|
|
2015-07-29 19:29:57 +05:00
|
|
|
toggleDropdown: function(e) {
|
|
|
|
|
$('.team__header').find('.dropdown-toggle').trigger('click');
|
|
|
|
|
},
|
|
|
|
|
|
2015-06-14 23:53:32 -08:00
|
|
|
render: function() {
|
2015-07-08 12:51:43 -07:00
|
|
|
var me = UserStore.getCurrentUser();
|
|
|
|
|
|
2015-07-15 09:03:28 -07:00
|
|
|
if (!me) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2015-06-14 23:53:32 -08:00
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className="team__header theme">
|
2015-07-29 19:29:57 +05:00
|
|
|
<a href="#" onClick={this.toggleDropdown}>
|
2015-07-22 20:38:40 +05:00
|
|
|
{ me.last_picture_update ?
|
2015-07-08 11:50:10 -04:00
|
|
|
<img className="user__picture" src={"/api/v1/users/" + me.id + "/image?time=" + me.update_at} />
|
2015-07-22 20:38:40 +05:00
|
|
|
:
|
2015-07-08 12:51:43 -07:00
|
|
|
null
|
2015-07-22 20:38:40 +05:00
|
|
|
}
|
2015-07-08 11:50:10 -04:00
|
|
|
<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>
|
2015-07-08 11:50:10 -04:00
|
|
|
</div>
|
|
|
|
|
</a>
|
2015-06-14 23:53:32 -08:00
|
|
|
<NavbarDropdown teamType={this.props.teamType} />
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
});
|