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-08-04 09:13:19 -07:00
|
|
|
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() {
|
2015-08-04 09:13:19 -07:00
|
|
|
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();
|
|
|
|
|
},
|
2015-07-30 10:54:41 -04:00
|
|
|
blockToggle: false,
|
2015-06-14 23:53:32 -08:00
|
|
|
componentDidMount: function() {
|
2015-08-04 09:13:19 -07:00
|
|
|
UserStore.addTeamsChangeListener(this.onListenerChange);
|
|
|
|
|
TeamStore.addChangeListener(this.onListenerChange);
|
2015-07-30 10:54:41 -04:00
|
|
|
|
|
|
|
|
var self = this;
|
2015-08-04 09:40:58 -07:00
|
|
|
$(this.refs.dropdown.getDOMNode()).on('hide.bs.dropdown', function() {
|
2015-07-30 10:54:41 -04:00
|
|
|
self.blockToggle = true;
|
2015-08-04 09:40:58 -07:00
|
|
|
setTimeout(function() {
|
|
|
|
|
self.blockToggle = false;
|
|
|
|
|
}, 100);
|
2015-07-30 10:54:41 -04:00
|
|
|
});
|
2015-06-14 23:53:32 -08:00
|
|
|
},
|
|
|
|
|
componentWillUnmount: function() {
|
2015-08-04 09:13:19 -07:00
|
|
|
UserStore.removeTeamsChangeListener(this.onListenerChange);
|
|
|
|
|
TeamStore.removeChangeListener(this.onListenerChange);
|
2015-07-30 12:11:01 -04:00
|
|
|
|
|
|
|
|
$(this.refs.dropdown.getDOMNode()).off('hide.bs.dropdown');
|
2015-06-14 23:53:32 -08:00
|
|
|
},
|
2015-08-04 09:13:19 -07: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() {
|
2015-08-04 09:40:58 -07:00
|
|
|
var teamLink = '';
|
|
|
|
|
var inviteLink = '';
|
|
|
|
|
var manageLink = '';
|
2015-07-15 09:03:28 -07:00
|
|
|
var currentUser = UserStore.getCurrentUser();
|
2015-06-14 23:53:32 -08:00
|
|
|
var isAdmin = false;
|
2015-08-04 09:40:58 -07:00
|
|
|
var teamSettings = null;
|
2015-06-14 23:53:32 -08:00
|
|
|
|
|
|
|
|
if (currentUser != null) {
|
2015-08-04 09:40:58 -07:00
|
|
|
isAdmin = currentUser.roles.indexOf('admin') > -1;
|
2015-06-14 23:53:32 -08:00
|
|
|
|
2015-08-04 09:40:58 -07:00
|
|
|
inviteLink = (<li> <a href='#' data-toggle='modal' data-target='#invite_member'>Invite New Member</a> </li>);
|
2015-06-14 23:53:32 -08:00
|
|
|
|
2015-08-04 09:40:58 -07:00
|
|
|
if (this.props.teamType === 'O') {
|
|
|
|
|
teamLink = (
|
2015-06-14 23:53:32 -08:00
|
|
|
<li>
|
2015-08-05 20:58:22 -07:00
|
|
|
<a href='#' data-toggle='modal' data-target='#get_link' data-title='Team Invite' data-value={utils.getWindowLocationOrigin() + '/signup_user_complete/?id=' + currentUser.team_id}>Get Team Invite Link</a>
|
2015-06-14 23:53:32 -08:00
|
|
|
</li>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (isAdmin) {
|
2015-08-04 09:40:58 -07:00
|
|
|
manageLink = (<li> <a href='#' data-toggle='modal' data-target='#team_members'>Manage Team</a> </li>);
|
|
|
|
|
teamSettings = (<li> <a href='#' data-toggle='modal' data-target='#team_settings'>Team Settings</a> </li>);
|
2015-06-14 23:53:32 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var teams = [];
|
|
|
|
|
|
2015-08-04 09:40:58 -07:00
|
|
|
teams.push(<li className='divider' key='div'></li>);
|
2015-08-04 09:13:19 -07:00
|
|
|
if (this.state.teams.length > 1 && this.state.currentTeam) {
|
|
|
|
|
var curTeamName = this.state.currentTeam.name;
|
|
|
|
|
this.state.teams.forEach(function(teamName) {
|
|
|
|
|
if (teamName !== curTeamName) {
|
2015-08-04 09:40:58 -07:00
|
|
|
teams.push(<li key={teamName}><a href={utils.getWindowLocationOrigin() + '/' + teamName}>Switch to {teamName}</a></li>);
|
2015-08-04 09:13:19 -07:00
|
|
|
}
|
|
|
|
|
});
|
2015-06-14 23:53:32 -08:00
|
|
|
}
|
2015-08-26 07:36:52 -07:00
|
|
|
teams.push(<li key='newTeam_li'><a key='newTeam_a' target="_blank" href={utils.getWindowLocationOrigin() + '/signup_team' }>Create a New Team</a></li>);
|
2015-06-14 23:53:32 -08:00
|
|
|
|
|
|
|
|
return (
|
2015-08-04 09:40:58 -07:00
|
|
|
<ul className='nav navbar-nav navbar-right'>
|
|
|
|
|
<li ref='dropdown' className='dropdown'>
|
|
|
|
|
<a href='#' className='dropdown-toggle' data-toggle='dropdown' role='button' aria-expanded='false'>
|
|
|
|
|
<span className='dropdown__icon' dangerouslySetInnerHTML={{__html: Constants.MENU_ICON}} />
|
2015-06-14 23:53:32 -08:00
|
|
|
</a>
|
2015-08-04 09:40:58 -07:00
|
|
|
<ul className='dropdown-menu' role='menu'>
|
2015-08-14 09:29:15 -07:00
|
|
|
<li><a href='#' data-toggle='modal' data-target='#user_settings'>Account Settings</a></li>
|
2015-08-04 09:40:58 -07:00
|
|
|
{teamSettings}
|
|
|
|
|
{inviteLink}
|
|
|
|
|
{teamLink}
|
|
|
|
|
{manageLink}
|
|
|
|
|
<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>
|
2015-06-14 23:53:32 -08:00
|
|
|
</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-08-04 09:40:58 -07:00
|
|
|
toggleDropdown: function() {
|
2015-07-30 10:54:41 -04:00
|
|
|
if (this.refs.dropdown.blockToggle) {
|
|
|
|
|
this.refs.dropdown.blockToggle = false;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
$('.team__header').find('.dropdown-toggle').dropdown('toggle');
|
2015-07-29 19:29:57 +05:00
|
|
|
},
|
|
|
|
|
|
2015-06-14 23:53:32 -08:00
|
|
|
render: function() {
|
2015-07-08 12:51:43 -07:00
|
|
|
var me = UserStore.getCurrentUser();
|
2015-08-04 09:40:58 -07:00
|
|
|
var profilePicture = null;
|
2015-07-08 12:51:43 -07:00
|
|
|
|
2015-07-15 09:03:28 -07:00
|
|
|
if (!me) {
|
|
|
|
|
return null;
|
|
|
|
|
}
|
2015-06-14 23:53:32 -08:00
|
|
|
|
2015-08-04 09:40:58 -07:00
|
|
|
if (me.last_picture_update) {
|
|
|
|
|
profilePicture = (<img className='user__picture' src={'/api/v1/users/' + me.id + '/image?time=' + me.update_at} />);
|
|
|
|
|
}
|
|
|
|
|
|
2015-06-14 23:53:32 -08:00
|
|
|
return (
|
2015-08-04 09:40:58 -07:00
|
|
|
<div className='team__header theme'>
|
|
|
|
|
<a href='#' onClick={this.toggleDropdown}>
|
|
|
|
|
{profilePicture}
|
|
|
|
|
<div className='header__info'>
|
|
|
|
|
<div className='user__name'>{'@' + me.username}</div>
|
|
|
|
|
<div className='team__name'>{this.props.teamDisplayName }</div>
|
2015-07-08 11:50:10 -04:00
|
|
|
</div>
|
|
|
|
|
</a>
|
2015-08-04 09:40:58 -07:00
|
|
|
<NavbarDropdown ref='dropdown' teamType={this.props.teamType} />
|
2015-06-14 23:53:32 -08:00
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
});
|