aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main
diff options
context:
space:
mode:
authorStas Vilchik <vilchiks@gmail.com>2016-11-04 14:31:27 +0100
committerGitHub <noreply@github.com>2016-11-04 14:31:27 +0100
commit3fdea0e46af7cc7080f5d232a192ae934787d0f9 (patch)
tree5aadcebf23cb3e9f80199609ede5e36fa7ace59b /server/sonar-web/src/main
parentb4cf2dbd2f3858b6a4e79c7c5b7d758fedd887bd (diff)
downloadsonarqube-3fdea0e46af7cc7080f5d232a192ae934787d0f9.tar.gz
sonarqube-3fdea0e46af7cc7080f5d232a192ae934787d0f9.zip
open projects page by default (#1358)
Diffstat (limited to 'server/sonar-web/src/main')
-rw-r--r--server/sonar-web/src/main/js/app/index.js2
-rw-r--r--server/sonar-web/src/main/js/app/store/rootReducer.js6
-rw-r--r--server/sonar-web/src/main/js/apps/account/account.css14
-rw-r--r--server/sonar-web/src/main/js/apps/account/components/Nav.js6
-rw-r--r--server/sonar-web/src/main/js/apps/account/components/UserCard.js11
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/components/FavoriteProjects.js145
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/components/IssuesActivity.js84
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/components/MyActivity.js53
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/components/MyActivityContainer.js28
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/store/actions.js56
-rw-r--r--server/sonar-web/src/main/js/apps/account/home/store/reducer.js32
-rw-r--r--server/sonar-web/src/main/js/apps/account/routes.js6
-rw-r--r--server/sonar-web/src/main/js/main/nav/global/global-nav-branding.js2
-rw-r--r--server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard_controller.rb2
14 files changed, 12 insertions, 435 deletions
diff --git a/server/sonar-web/src/main/js/app/index.js b/server/sonar-web/src/main/js/app/index.js
index 107dc2ae53c..84268cf4861 100644
--- a/server/sonar-web/src/main/js/app/index.js
+++ b/server/sonar-web/src/main/js/app/index.js
@@ -44,7 +44,7 @@ window.sonarqube.appStarted.then(options => {
<Provider store={store}>
<Router history={history}>
<Route path="/" component={App}>
- {accountRoutes}
+ <Route path="account">{accountRoutes}</Route>
{projectsRoutes}
{qualityGatesRoutes}
{qualityProfilesRoutes}
diff --git a/server/sonar-web/src/main/js/app/store/rootReducer.js b/server/sonar-web/src/main/js/app/store/rootReducer.js
index a317c982af6..3c2ac6abb2b 100644
--- a/server/sonar-web/src/main/js/app/store/rootReducer.js
+++ b/server/sonar-web/src/main/js/app/store/rootReducer.js
@@ -25,7 +25,6 @@ import languages, * as fromLanguages from './languages/reducer';
import measures, * as fromMeasures from './measures/reducer';
import globalMessages, * as fromGlobalMessages from '../../components/store/globalMessages';
-import issuesActivity, * as fromIssuesActivity from '../../apps/account/home/store/reducer';
import projectsApp, * as fromProjectsApp from '../../apps/projects/store/reducer';
import qualityGatesApp from '../../apps/quality-gates/store/rootReducer';
@@ -38,7 +37,6 @@ export default combineReducers({
users,
// apps
- issuesActivity,
projectsApp,
qualityGatesApp
});
@@ -63,10 +61,6 @@ export const getFavorites = state => (
fromFavorites.getFavorites(state.favorites)
);
-export const getIssuesActivity = state => (
- fromIssuesActivity.getIssuesActivity(state.issuesActivity)
-);
-
export const getComponentMeasure = (state, componentKey, metricKey) => (
fromMeasures.getComponentMeasure(state.measures, componentKey, metricKey)
);
diff --git a/server/sonar-web/src/main/js/apps/account/account.css b/server/sonar-web/src/main/js/apps/account/account.css
index 130a53eabf3..10410996517 100644
--- a/server/sonar-web/src/main/js/apps/account/account.css
+++ b/server/sonar-web/src/main/js/apps/account/account.css
@@ -30,20 +30,6 @@
float: left;
}
-.account-user > a {
- display: block;
- float: left;
- margin: -10px -15px -10px -10px;
- padding: 10px 15px 10px 10px;
- border-bottom: none;
- border-radius: 3px;
-}
-
-.account-user > a:hover,
-.account-user > a:active {
- background-color: rgba(0, 0, 0, 0.075);
-}
-
.account-user h1 {
line-height: 60px;
}
diff --git a/server/sonar-web/src/main/js/apps/account/components/Nav.js b/server/sonar-web/src/main/js/apps/account/components/Nav.js
index d7e4b1215de..f1c94137e74 100644
--- a/server/sonar-web/src/main/js/apps/account/components/Nav.js
+++ b/server/sonar-web/src/main/js/apps/account/components/Nav.js
@@ -18,16 +18,16 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
-import { Link } from 'react-router';
+import { Link, IndexLink } from 'react-router';
import { translate } from '../../../helpers/l10n';
const Nav = () => (
<nav className="account-nav clearfix">
<ul className="nav navbar-nav nav-tabs">
<li>
- <Link to="/account/profile/" activeClassName="active">
+ <IndexLink to="/account/" activeClassName="active">
{translate('my_account.profile')}
- </Link>
+ </IndexLink>
</li>
<li>
<Link to="/account/security/" activeClassName="active">
diff --git a/server/sonar-web/src/main/js/apps/account/components/UserCard.js b/server/sonar-web/src/main/js/apps/account/components/UserCard.js
index c9fc9674173..da25ea529d7 100644
--- a/server/sonar-web/src/main/js/apps/account/components/UserCard.js
+++ b/server/sonar-web/src/main/js/apps/account/components/UserCard.js
@@ -18,7 +18,6 @@
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
import React from 'react';
-import { IndexLink } from 'react-router';
import Avatar from '../../../components/ui/Avatar';
export default class UserCard extends React.Component {
@@ -31,12 +30,10 @@ export default class UserCard extends React.Component {
return (
<div className="account-user">
- <IndexLink to="/account/">
- <div id="avatar" className="pull-left account-user-avatar">
- <Avatar email={user.email} size={60}/>
- </div>
- <h1 id="name" className="pull-left">{user.name}</h1>
- </IndexLink>
+ <div id="avatar" className="pull-left account-user-avatar">
+ <Avatar email={user.email} size={60}/>
+ </div>
+ <h1 id="name" className="pull-left">{user.name}</h1>
</div>
);
}
diff --git a/server/sonar-web/src/main/js/apps/account/home/components/FavoriteProjects.js b/server/sonar-web/src/main/js/apps/account/home/components/FavoriteProjects.js
deleted file mode 100644
index c8cf522e686..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/components/FavoriteProjects.js
+++ /dev/null
@@ -1,145 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import React from 'react';
-import { connect } from 'react-redux';
-import sortBy from 'lodash/sortBy';
-import Favorite from '../../../../components/controls/Favorite';
-import Level from '../../../../components/ui/Level';
-import { TooltipsContainer } from '../../../../components/mixins/tooltips-mixin';
-import { getFavorites, getComponentMeasure } from '../../../../app/store/rootReducer';
-import { getComponentUrl, getProjectsUrl } from '../../../../helpers/urls';
-import { fetchFavoriteProjects } from '../store/actions';
-import { translate } from '../../../../helpers/l10n';
-
-class FavoriteProjects extends React.Component {
- static propTypes = {
- favorites: React.PropTypes.array,
- fetchFavoriteProjects: React.PropTypes.func.isRequired
- };
-
- componentDidMount () {
- this.props.fetchFavoriteProjects();
- }
-
- renderList () {
- const { favorites } = this.props;
-
- if (!favorites) {
- return null;
- }
-
- if (favorites.length === 0) {
- return (
- <div id="no-favorite-projects" className="boxed-group boxed-group-inner markdown text-center">
- <p className="note">{translate('my_activity.no_favorite_projects')}</p>
- <p>{translate('my_activity.no_favorite_projects.engagement')}</p>
- </div>
- );
- }
-
- const sorted = sortBy(favorites, project => project.name.toLowerCase());
-
- return (
- <ul id="favorite-projects">
- {sorted.map(project => (
- <li key={project.key}>
- <div className="pull-left" style={{ padding: '15px 15px 15px 10px' }}>
- <Favorite favorite={true} component={project.key}/>
- </div>
-
- <a href={getComponentUrl(project.key)}>
- {project.qualityGate != null && (
- <span className="pull-right">
- <Level level={project.qualityGate}/>
- </span>
- )}
- <strong>{project.name}</strong>
- </a>
- </li>
- ))}
- </ul>
- );
- }
-
- renderQualityGateTitle () {
- const { favorites } = this.props;
-
- const shouldBeRendered = favorites != null && favorites.some(f => f.qualityGate != null);
-
- if (!shouldBeRendered) {
- return null;
- }
-
- return (
- <TooltipsContainer>
- <div className="pull-right note">
- {translate('overview.quality_gate')}
- <i className="little-spacer-left icon-help"
- title={translate('quality_gates.intro.1')}
- data-toggle="tooltip"/>
- </div>
- </TooltipsContainer>
- );
- }
-
- render () {
- const { favorites } = this.props;
-
- return (
- <div className="my-activity-projects">
- <div className="my-activity-projects-header">
- {this.renderQualityGateTitle()}
- <h2>{translate('my_activity.my_favorite_projects')}</h2>
- </div>
-
- {favorites == null && (
- <div className="text-center">
- <i className="spinner"/>
- </div>
- )}
-
- {this.renderList()}
-
- <div className="more">
- <a className="button" href={getProjectsUrl()}>
- {translate('my_activity.explore_projects')}
- </a>
- </div>
- </div>
- );
- }
-}
-
-const mapStateToProps = state => {
- const fromState = getFavorites(state);
- const favorites = fromState == null ? null : fromState
- .filter(component => component.qualifier === 'TRK')
- .map(component => ({
- ...component,
- qualityGate: getComponentMeasure(state, component.key, 'alert_status')
- }));
-
- return { favorites };
-};
-
-export default connect(
- mapStateToProps,
- { fetchFavoriteProjects }
-)(FavoriteProjects);
diff --git a/server/sonar-web/src/main/js/apps/account/home/components/IssuesActivity.js b/server/sonar-web/src/main/js/apps/account/home/components/IssuesActivity.js
deleted file mode 100644
index 26200df619f..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/components/IssuesActivity.js
+++ /dev/null
@@ -1,84 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import React from 'react';
-import { connect } from 'react-redux';
-import { fetchIssuesActivity } from '../store/actions';
-import { getIssuesActivity } from '../../../../app/store/rootReducer';
-import { getIssuesUrl } from '../../../../helpers/urls';
-import { translate } from '../../../../helpers/l10n';
-
-class IssuesActivity extends React.Component {
- componentDidMount () {
- this.props.fetchIssuesActivity();
- }
-
- getColorClass (number) {
- if (number == null) {
- return '';
- }
- return number > 0 ? 'text-danger' : 'text-success';
- }
-
- renderRecentIssues () {
- const number = this.props.issuesActivity && this.props.issuesActivity.recent;
- const url = getIssuesUrl({ resolved: 'false', assignees: '__me__', createdInLast: '1w' });
-
- return (
- <a className="my-activity-recent-issues" href={url}>
- <div id="recent-issues" className={'my-activity-issues-number ' + this.getColorClass(number)}>
- {number != null ? number : ' ' }
- </div>
- <div className="my-activity-issues-note">
- {translate('my_activity.my_issues')}<br/>{translate('my_activity.last_week')}
- </div>
- </a>
- );
- }
-
- renderAllIssues () {
- const number = this.props.issuesActivity && this.props.issuesActivity.all;
- const url = getIssuesUrl({ resolved: 'false', assignees: '__me__' });
-
- return (
- <a className="my-activity-all-issues" href={url}>
- <div id="all-issues" className={'my-activity-issues-number ' + this.getColorClass(number)}>
- {number != null ? number : ' ' }
- </div>
- <div className="my-activity-issues-note">
- {translate('my_activity.my_issues')}<br/>{translate('my_activity.all_time')}
- </div>
- </a>
- );
- }
-
- render () {
- return (
- <div className="my-activity-issues">
- {this.renderRecentIssues()}
- {this.renderAllIssues()}
- </div>
- );
- }
-}
-
-export default connect(
- state => ({ issuesActivity: getIssuesActivity(state) }),
- { fetchIssuesActivity }
-)(IssuesActivity);
diff --git a/server/sonar-web/src/main/js/apps/account/home/components/MyActivity.js b/server/sonar-web/src/main/js/apps/account/home/components/MyActivity.js
deleted file mode 100644
index 43d13d066b2..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/components/MyActivity.js
+++ /dev/null
@@ -1,53 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import React from 'react';
-import IssuesActivity from './IssuesActivity';
-import FavoriteProjects from './FavoriteProjects';
-
-export default class MyActivity extends React.Component {
- static propTypes = {
- currentUser: React.PropTypes.object
- };
-
- render () {
- const { currentUser } = this.props;
-
- return (
- <div id="my-activity-page">
-
- {currentUser == null ? (
-
- <div className="account-body text-center">
- <i className="spinner"/>
- </div>
-
- ) : (
-
- <div className="account-body">
- <IssuesActivity/>
- <FavoriteProjects/>
- </div>
-
- )}
-
- </div>
- );
- }
-}
diff --git a/server/sonar-web/src/main/js/apps/account/home/components/MyActivityContainer.js b/server/sonar-web/src/main/js/apps/account/home/components/MyActivityContainer.js
deleted file mode 100644
index 2e1b98636ff..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/components/MyActivityContainer.js
+++ /dev/null
@@ -1,28 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import { connect } from 'react-redux';
-import MyActivity from './MyActivity';
-import { getCurrentUser } from '../../../../app/store/rootReducer';
-
-const mapStateToProps = state => ({
- currentUser: getCurrentUser(state)
-});
-
-export default connect(mapStateToProps)(MyActivity);
diff --git a/server/sonar-web/src/main/js/apps/account/home/store/actions.js b/server/sonar-web/src/main/js/apps/account/home/store/actions.js
deleted file mode 100644
index 3bb645a926d..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/store/actions.js
+++ /dev/null
@@ -1,56 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import { getIssuesCount } from '../../../../api/issues';
-import { getFavorites } from '../../../../api/favorites';
-import { receiveFavorites } from '../../../../app/store/favorites/actions';
-import { getMeasures } from '../../../../api/measures';
-import { receiveComponentMeasure } from '../../../../app/store/measures/actions';
-
-export const RECEIVE_ISSUES_ACTIVITY = 'myActivity/RECEIVE_ISSUES_ACTIVITY';
-
-const receiveIssuesActivity = (recent, all) => ({
- type: RECEIVE_ISSUES_ACTIVITY,
- recent,
- all
-});
-
-export const fetchIssuesActivity = () => dispatch => {
- const query = { resolved: 'false', assignees: '__me__' };
- Promise.all([
- getIssuesCount(query),
- getIssuesCount({ ...query, createdInLast: '1w' })
- ]).then(responses => dispatch(receiveIssuesActivity(responses[1].issues, responses[0].issues)));
-};
-
-export const fetchFavoriteProjects = () => dispatch => {
- getFavorites().then(favorites => {
- dispatch(receiveFavorites(favorites));
-
- const projects = favorites.filter(component => component.qualifier === 'TRK');
- Promise.all(projects.map(project => getMeasures(project.key, ['alert_status'])))
- .then(responses => {
- responses.forEach((measures, index) => {
- measures.forEach(measure => {
- dispatch(receiveComponentMeasure(projects[index].key, measure.metric, measure.value));
- });
- });
- });
- });
-};
diff --git a/server/sonar-web/src/main/js/apps/account/home/store/reducer.js b/server/sonar-web/src/main/js/apps/account/home/store/reducer.js
deleted file mode 100644
index 3cf1b341303..00000000000
--- a/server/sonar-web/src/main/js/apps/account/home/store/reducer.js
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation; either
- * version 3 of the License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-import { RECEIVE_ISSUES_ACTIVITY } from './actions';
-
-const reducer = (state = null, action = {}) => {
- if (action.type === RECEIVE_ISSUES_ACTIVITY) {
- return { all: action.all, recent: action.recent };
- }
-
- return state;
-};
-
-export default reducer;
-
-export const getIssuesActivity = state => state;
diff --git a/server/sonar-web/src/main/js/apps/account/routes.js b/server/sonar-web/src/main/js/apps/account/routes.js
index e16ea776ae4..212a2f82108 100644
--- a/server/sonar-web/src/main/js/apps/account/routes.js
+++ b/server/sonar-web/src/main/js/apps/account/routes.js
@@ -19,7 +19,6 @@
*/
import React from 'react';
import { Route, IndexRoute } from 'react-router';
-import MyActivityContainer from './home/components/MyActivityContainer';
import Account from './components/Account';
import ProjectsContainer from './projects/ProjectsContainer';
import NotificationsContainer from './notifications/NotificationsContainer';
@@ -27,9 +26,8 @@ import Security from './components/Security';
import Profile from './profile/Profile';
export default (
- <Route path="account" component={Account}>
- <IndexRoute component={MyActivityContainer}/>
- <Route path="profile" component={Profile}/>
+ <Route component={Account}>
+ <IndexRoute component={Profile}/>
<Route path="security" component={Security}/>
<Route path="notifications" component={NotificationsContainer}/>
<Route path="projects" component={ProjectsContainer}/>
diff --git a/server/sonar-web/src/main/js/main/nav/global/global-nav-branding.js b/server/sonar-web/src/main/js/main/nav/global/global-nav-branding.js
index d012ae232bb..2c33fea9724 100644
--- a/server/sonar-web/src/main/js/main/nav/global/global-nav-branding.js
+++ b/server/sonar-web/src/main/js/main/nav/global/global-nav-branding.js
@@ -34,7 +34,7 @@ export default React.createClass({
},
render() {
- const homeController = window.SS.user ? '/account' : '/';
+ const homeController = window.SS.user ? '/projects/favorite' : '/projects';
const homeUrl = window.baseUrl + homeController;
const homeLinkClassName = 'navbar-brand' + (this.props.logoUrl ? ' navbar-brand-custom' : '');
return (
diff --git a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard_controller.rb b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard_controller.rb
index 4fb0a3fc1e6..867b7cc9792 100644
--- a/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard_controller.rb
+++ b/server/sonar-web/src/main/webapp/WEB-INF/app/controllers/dashboard_controller.rb
@@ -54,7 +54,7 @@ class DashboardController < ApplicationController
end
else
if logged_in?
- return redirect_to :controller => 'account'
+ return redirect_to :controller => 'projects', :action => 'favorite'
else
return redirect_to :controller => 'projects'
end