diff options
author | Grégoire Aubert <gregoire.aubert@sonarsource.com> | 2017-04-28 11:24:03 +0200 |
---|---|---|
committer | Grégoire Aubert <gregaubert@users.noreply.github.com> | 2017-04-28 15:32:07 +0200 |
commit | f64450ef7cf35b30c4730491e9f30f31f688b98b (patch) | |
tree | bf93c529001d6694ccdfb7137a75a902c0b60952 /server/sonar-web/src/main/js/apps/about | |
parent | 5d361e9ec5437d9402d95939b630796494416021 (diff) | |
download | sonarqube-f64450ef7cf35b30c4730491e9f30f31f688b98b.tar.gz sonarqube-f64450ef7cf35b30c4730491e9f30f31f688b98b.zip |
SONAR-9047 Only load google fonts on sonarqube.com instances
Diffstat (limited to 'server/sonar-web/src/main/js/apps/about')
-rw-r--r-- | server/sonar-web/src/main/js/apps/about/components/AboutApp.js | 4 | ||||
-rw-r--r-- | server/sonar-web/src/main/js/apps/about/components/AboutAppForSonarQubeDotComLazyLoader.js | 47 |
2 files changed, 49 insertions, 2 deletions
diff --git a/server/sonar-web/src/main/js/apps/about/components/AboutApp.js b/server/sonar-web/src/main/js/apps/about/components/AboutApp.js index 9485847305b..ee0a05da356 100644 --- a/server/sonar-web/src/main/js/apps/about/components/AboutApp.js +++ b/server/sonar-web/src/main/js/apps/about/components/AboutApp.js @@ -36,7 +36,7 @@ import { getFacet } from '../../../api/issues'; import { getAppState, getCurrentUser, getSettingValue } from '../../../store/rootReducer'; import { translate } from '../../../helpers/l10n'; import { fetchAboutPageSettings } from '../actions'; -import AboutAppForSonarQubeDotCom from './AboutAppForSonarQubeDotCom'; +import AboutAppForSonarQubeDotComLazyLoader from './AboutAppForSonarQubeDotComLazyLoader'; import '../styles.css'; type State = { @@ -119,7 +119,7 @@ class AboutApp extends React.PureComponent { if (sonarqubeDotCom && sonarqubeDotCom.value === 'true') { return ( - <AboutAppForSonarQubeDotCom + <AboutAppForSonarQubeDotComLazyLoader appState={this.props.appState} bugs={bugs} codeSmells={codeSmells} diff --git a/server/sonar-web/src/main/js/apps/about/components/AboutAppForSonarQubeDotComLazyLoader.js b/server/sonar-web/src/main/js/apps/about/components/AboutAppForSonarQubeDotComLazyLoader.js new file mode 100644 index 00000000000..5af2402c06e --- /dev/null +++ b/server/sonar-web/src/main/js/apps/about/components/AboutAppForSonarQubeDotComLazyLoader.js @@ -0,0 +1,47 @@ +/* + * 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. + */ +import React from 'react'; + +export default class AboutAppForSonarQubeDotComLazyLoader extends React.PureComponent { + constructor(props) { + super(props); + this.state = { + AboutAppForSonarQubeDotCom: null + }; + } + + componentDidMount() { + if (!this.state.AboutAppForSonarQubeDotCom) { + require.ensure([], require => { + this.setState({ + AboutAppForSonarQubeDotCom: require('./AboutAppForSonarQubeDotCom').default + }); + }); + } + } + + render() { + const { AboutAppForSonarQubeDotCom } = this.state; + if (AboutAppForSonarQubeDotCom) { + return <AboutAppForSonarQubeDotCom {...this.props} />; + } + return null; + } +} |