diff options
author | Grégoire Aubert <gregoire.aubert@sonarsource.com> | 2017-07-19 15:10:29 +0200 |
---|---|---|
committer | Grégoire Aubert <gregoire.aubert@sonarsource.com> | 2017-07-25 09:20:30 +0200 |
commit | c86db4ee3737107b738e2bd83d5cfbad5d3575f2 (patch) | |
tree | 11267bf2cb1f5a957547164cd7c13aa25e7b5731 /server/sonar-web | |
parent | 5990dc0b10ad7cdd3e09b9eb8d0b636795d94c7b (diff) | |
download | sonarqube-c86db4ee3737107b738e2bd83d5cfbad5d3575f2.tar.gz sonarqube-c86db4ee3737107b738e2bd83d5cfbad5d3575f2.zip |
SONAR-9566 Add Issues link at organization level navbar
Diffstat (limited to 'server/sonar-web')
-rw-r--r-- | server/sonar-web/src/main/js/apps/issues/components/App.js | 9 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/components/OrganizationContainer.js (renamed from server/sonar-web/src/main/js/apps/organizations/components/OrganizationProjectsContainer.js) | 7 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/components/OrganizationPage.js | 12 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js | 17 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/OrganizationNavigation-test.js | 7 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap | 51 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/organizations/routes.js | 10 |
7 files changed, 100 insertions, 13 deletions
diff --git a/server/sonar-web/src/main/js/apps/issues/components/App.js b/server/sonar-web/src/main/js/apps/issues/components/App.js index 60dd9d43f9f..48b6dbfcb0c 100644 --- a/server/sonar-web/src/main/js/apps/issues/components/App.js +++ b/server/sonar-web/src/main/js/apps/issues/components/App.js @@ -67,6 +67,7 @@ export type Props = { fetchIssues: (query: RawQuery) => Promise<*>, location: { pathname: string, query: RawQuery }, onRequestFail: Error => void, + organization?: { key: string }, router: { push: ({ pathname: string, query?: RawQuery }) => void, replace: ({ pathname: string, query?: RawQuery }) => void @@ -342,7 +343,7 @@ export default class App extends React.PureComponent { }; fetchIssues = (additional?: {}, requestFacets?: boolean = false): Promise<*> => { - const { component } = this.props; + const { component, organization } = this.props; const { myIssues, openFacets, query } = this.state; const facets = requestFacets @@ -358,6 +359,10 @@ export default class App extends React.PureComponent { ...additional }; + if (organization) { + parameters.organization = organization.key; + } + // only sorting by CREATION_DATE is allowed, so let's sort DESC if (query.sort) { Object.assign(parameters, { asc: 'false' }); @@ -730,7 +735,7 @@ export default class App extends React.PureComponent { } renderSide(openIssue: ?Issue) { - const top = this.props.component ? 95 : 30; + const top = this.props.component || this.props.organization ? 95 : 30; return ( <div className="layout-page-side-outer"> diff --git a/server/sonar-web/src/main/js/apps/organizations/components/OrganizationProjectsContainer.js b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationContainer.js index a08e864d1b9..a48cf7f5cd6 100644 --- a/server/sonar-web/src/main/js/apps/organizations/components/OrganizationProjectsContainer.js +++ b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationContainer.js @@ -21,9 +21,8 @@ import React from 'react'; import { connect } from 'react-redux'; import { getCurrentUser, getOrganizationByKey } from '../../../store/rootReducer'; -import { updateOrganization } from '../actions'; -class OrganizationProjectsContainer extends React.PureComponent { +class OrganizationContainer extends React.PureComponent { render() { return React.cloneElement(this.props.children, { currentUser: this.props.currentUser, @@ -37,6 +36,4 @@ const mapStateToProps = (state, ownProps) => ({ currentUser: getCurrentUser(state) }); -const mapDispatchToProps = { updateOrganization }; - -export default connect(mapStateToProps, mapDispatchToProps)(OrganizationProjectsContainer); +export default connect(mapStateToProps)(OrganizationContainer); diff --git a/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPage.js b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPage.js index d08cfabf5d4..9111c0c70e2 100644 --- a/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPage.js +++ b/server/sonar-web/src/main/js/apps/organizations/components/OrganizationPage.js @@ -22,10 +22,10 @@ import React from 'react'; import Helmet from 'react-helmet'; import { connect } from 'react-redux'; import OrganizationNavigation from '../navigation/OrganizationNavigation'; +import NotFound from '../../../app/components/NotFound'; import { fetchOrganization } from '../actions'; -import { getOrganizationByKey } from '../../../store/rootReducer'; +import { getCurrentUser, getOrganizationByKey } from '../../../store/rootReducer'; import type { Organization } from '../../../store/organizations/duck'; -import NotFound from '../../../app/components/NotFound'; type OwnProps = { params: { organizationKey: string } @@ -33,6 +33,7 @@ type OwnProps = { type Props = { children?: React.Element<*>, + currentUser: { isLoggedIn: boolean, showOnboardingTutorial: true }, location: Object, organization: null | Organization, params: { organizationKey: string }, @@ -88,7 +89,11 @@ class OrganizationPage extends React.PureComponent { return ( <div> <Helmet defaultTitle={organization.name} titleTemplate={'%s - ' + organization.name} /> - <OrganizationNavigation organization={organization} location={this.props.location} /> + <OrganizationNavigation + currentUser={this.props.currentUser} + organization={organization} + location={this.props.location} + /> {this.props.children} </div> ); @@ -96,6 +101,7 @@ class OrganizationPage extends React.PureComponent { } const mapStateToProps = (state, ownProps: OwnProps) => ({ + currentUser: getCurrentUser(state), organization: getOrganizationByKey(state, ownProps.params.organizationKey) }); diff --git a/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js b/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js index e872e6e2ac1..ab54c533014 100644 --- a/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js +++ b/server/sonar-web/src/main/js/apps/organizations/navigation/OrganizationNavigation.js @@ -25,6 +25,7 @@ import { translate } from '../../../helpers/l10n'; import ContextNavBar from '../../../components/nav/ContextNavBar'; import NavBarTabs from '../../../components/nav/NavBarTabs'; import OrganizationIcon from '../../../components/icons-components/OrganizationIcon'; +import { isMySet } from '../../issues/utils'; import type { Organization } from '../../../store/organizations/duck'; const ADMIN_PATHS = [ @@ -38,6 +39,7 @@ const ADMIN_PATHS = [ export default class OrganizationNavigation extends React.PureComponent { props: { + currentUser: { isLoggedIn: boolean, showOnboardingTutorial: true }, location: { pathname: string }, organization: Organization }; @@ -135,7 +137,7 @@ export default class OrganizationNavigation extends React.PureComponent { } render() { - const { organization, location } = this.props; + const { currentUser, organization, location } = this.props; const isHomeActive = location.pathname === `organizations/${organization.key}/projects` || @@ -197,6 +199,19 @@ export default class OrganizationNavigation extends React.PureComponent { </Link> </li> <li> + <Link + to={{ + pathname: `/organizations/${organization.key}/issues`, + query: + currentUser.isLoggedIn && isMySet() + ? { resolved: 'false', myIssues: 'true' } + : { resolved: 'false' } + }} + activeClassName="active"> + {translate('issues.page')} + </Link> + </li> + <li> <Link to={`/organizations/${organization.key}/members`} activeClassName="active"> {translate('organization.members.page')} </Link> diff --git a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/OrganizationNavigation-test.js b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/OrganizationNavigation-test.js index 09254c5aaf3..f4a2b09a38b 100644 --- a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/OrganizationNavigation-test.js +++ b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/OrganizationNavigation-test.js @@ -21,11 +21,16 @@ import React from 'react'; import { shallow } from 'enzyme'; import OrganizationNavigation from '../OrganizationNavigation'; +jest.mock('../../../issues/utils', () => ({ + isMySet: () => false +})); + it('regular user', () => { const organization = { key: 'foo', name: 'Foo', canAdmin: false, canDelete: false }; expect( shallow( <OrganizationNavigation + currentUser={{ isLoggedIn: true }} location={{ pathname: '/organizations/foo' }} organization={organization} /> @@ -38,6 +43,7 @@ it('admin', () => { expect( shallow( <OrganizationNavigation + currentUser={{ isLoggedIn: true }} location={{ pathname: '/organizations/foo' }} organization={organization} /> @@ -50,6 +56,7 @@ it('undeletable org', () => { expect( shallow( <OrganizationNavigation + currentUser={{ isLoggedIn: true }} location={{ pathname: '/organizations/foo' }} organization={organization} /> diff --git a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap index 05104c2e4d8..389fae8e92f 100644 --- a/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap +++ b/server/sonar-web/src/main/js/apps/organizations/navigation/__tests__/__snapshots__/OrganizationNavigation-test.js.snap @@ -45,6 +45,23 @@ exports[`admin 1`] = ` activeClassName="active" onlyActiveOnIndex={false} style={Object {}} + to={ + Object { + "pathname": "/organizations/foo/issues", + "query": Object { + "resolved": "false", + }, + } + } + > + issues.page + </Link> + </li> + <li> + <Link + activeClassName="active" + onlyActiveOnIndex={false} + style={Object {}} to="/organizations/foo/members" > organization.members.page @@ -198,6 +215,23 @@ exports[`regular user 1`] = ` activeClassName="active" onlyActiveOnIndex={false} style={Object {}} + to={ + Object { + "pathname": "/organizations/foo/issues", + "query": Object { + "resolved": "false", + }, + } + } + > + issues.page + </Link> + </li> + <li> + <Link + activeClassName="active" + onlyActiveOnIndex={false} + style={Object {}} to="/organizations/foo/members" > organization.members.page @@ -272,6 +306,23 @@ exports[`undeletable org 1`] = ` activeClassName="active" onlyActiveOnIndex={false} style={Object {}} + to={ + Object { + "pathname": "/organizations/foo/issues", + "query": Object { + "resolved": "false", + }, + } + } + > + issues.page + </Link> + </li> + <li> + <Link + activeClassName="active" + onlyActiveOnIndex={false} + style={Object {}} to="/organizations/foo/members" > organization.members.page diff --git a/server/sonar-web/src/main/js/apps/organizations/routes.js b/server/sonar-web/src/main/js/apps/organizations/routes.js index f5880608456..90c22b3270b 100644 --- a/server/sonar-web/src/main/js/apps/organizations/routes.js +++ b/server/sonar-web/src/main/js/apps/organizations/routes.js @@ -19,8 +19,8 @@ */ import OrganizationPage from './components/OrganizationPage'; import OrganizationPageExtension from '../../app/components/extensions/OrganizationPageExtension'; +import OrganizationContainer from './components/OrganizationContainer'; import OrganizationProjects from './components/OrganizationProjects'; -import OrganizationProjectsContainer from './components/OrganizationProjectsContainer'; import OrganizationFavoriteProjects from './components/OrganizationFavoriteProjects'; import OrganizationRules from './components/OrganizationRules'; import OrganizationAdmin from './components/OrganizationAdmin'; @@ -32,6 +32,7 @@ import OrganizationPermissionTemplates from './components/OrganizationPermission import OrganizationProjectsManagement from './components/OrganizationProjectsManagement'; import OrganizationDelete from './components/OrganizationDelete'; import qualityProfilesRoutes from '../quality-profiles/routes'; +import issuesRoutes from '../issues/routes'; const routes = [ { @@ -48,7 +49,7 @@ const routes = [ }, { path: 'projects', - component: OrganizationProjectsContainer, + component: OrganizationContainer, childRoutes: [ { indexRoute: { @@ -62,6 +63,11 @@ const routes = [ ] }, { + path: 'issues', + component: OrganizationContainer, + childRoutes: issuesRoutes + }, + { path: 'members', component: OrganizationMembersContainer }, |