/* * SonarQube * Copyright (C) 2009-2017 SonarSource SA * mailto:info 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. */ // @flow import React from 'react'; import { connect } from 'react-redux'; import ComponentNav from './nav/component/ComponentNav'; import { fetchProject } from '../../store/rootActions'; import { getComponent } from '../../store/rootReducer'; import { addGlobalErrorMessage } from '../../store/globalMessages/duck'; import { parseError } from '../../apps/code/utils'; import handleRequiredAuthorization from '../utils/handleRequiredAuthorization'; class ProjectContainer extends React.Component { props: { addGlobalErrorMessage: () => void, children: {}, location: { query: { id: string } }, project?: { configuration: {}, qualifier: string }, fetchProject: (string) => Promise<*> }; componentDidMount() { this.fetchProject(); } componentDidUpdate(prevProps) { if (prevProps.location.query.id !== this.props.location.query.id) { this.fetchProject(); } } fetchProject() { this.props.fetchProject(this.props.location.query.id).catch(e => { if (e.response.status === 403) { handleRequiredAuthorization(); } else { parseError(e).then(message => this.props.addGlobalErrorMessage(message)); } }); } render() { // check `breadcrumbs` to be sure that /api/navigation/component has been already called if (!this.props.project || this.props.project.breadcrumbs == null) { return null; } const isFile = ['FIL', 'UTS'].includes(this.props.project.qualifier); // $FlowFixMe `this.props.project` is always defined at this point const configuration = this.props.project.configuration || {}; return (
{!isFile && } {this.props.children}
); } } const mapStateToProps = (state, ownProps) => ({ project: getComponent(state, ownProps.location.query.id) }); const mapDispatchToProps = { addGlobalErrorMessage, fetchProject }; export default connect(mapStateToProps, mapDispatchToProps)(ProjectContainer);