aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js
diff options
context:
space:
mode:
authorGrégoire Aubert <gregoire.aubert@sonarsource.com>2018-02-22 14:29:30 +0100
committerGrégoire Aubert <gregoire.aubert@sonarsource.com>2018-02-23 16:34:13 +0100
commitaa0ced5bc4a11dc28a5f8e298b03e7011bcb62d3 (patch)
tree3be335a3c39040992dc8e3e2051c00b87c925492 /server/sonar-web/src/main/js
parent5b3eaeebc6e69dc03d794cc0febcacb48408cf10 (diff)
downloadsonarqube-aa0ced5bc4a11dc28a5f8e298b03e7011bcb62d3.tar.gz
sonarqube-aa0ced5bc4a11dc28a5f8e298b03e7011bcb62d3.zip
SONAR-10440 Remove useless tooltips on project overview measures
Diffstat (limited to 'server/sonar-web/src/main/js')
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.tsx (renamed from server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.js)40
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/OverviewApp.tsx4
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.tsx (renamed from server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.js)5
-rw-r--r--server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.tsx.snap (renamed from server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.js.snap)0
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx (renamed from server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.js)13
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx (renamed from server/sonar-web/src/main/js/apps/overview/main/CodeSmells.js)34
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/Coverage.tsx (renamed from server/sonar-web/src/main/js/apps/overview/main/Coverage.js)55
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/Duplications.tsx (renamed from server/sonar-web/src/main/js/apps/overview/main/Duplications.js)38
-rw-r--r--server/sonar-web/src/main/js/apps/overview/main/enhance.tsx23
9 files changed, 88 insertions, 124 deletions
diff --git a/server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.js b/server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.tsx
index bc0704b005a..55d8c5082ce 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/ApplicationLeakPeriodLegend.tsx
@@ -17,39 +17,31 @@
* 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 * as React from 'react';
import Tooltip from '../../../components/controls/Tooltip';
import DateTooltipFormatter from '../../../components/intl/DateTooltipFormatter';
import { getApplicationLeak } from '../../../api/application';
import { translate } from '../../../helpers/l10n';
-/*::
-type Props = {
- component: { key: string }
-};
-*/
+interface Props {
+ component: string;
+}
-/*::
-type State = {
- leaks: ?Array<{ date: string, project: string, projectName: string }>
-};
-*/
+interface State {
+ leaks?: Array<{ date: string; project: string; projectName: string }>;
+}
-export default class ApplicationLeakPeriodLegend extends React.Component {
- /*:: mounted: boolean; */
- /*:: props: Props; */
- state /*: State */ = {
- leaks: null
- };
+export default class ApplicationLeakPeriodLegend extends React.Component<Props, State> {
+ mounted = false;
+ state: State = {};
componentDidMount() {
this.mounted = true;
}
- componentWillReceiveProps(nextProps /*: Props */) {
- if (nextProps.component.key !== this.props.component.key) {
- this.setState({ leaks: null });
+ componentWillReceiveProps(nextProps: Props) {
+ if (nextProps.component !== this.props.component) {
+ this.setState({ leaks: undefined });
}
}
@@ -57,9 +49,9 @@ export default class ApplicationLeakPeriodLegend extends React.Component {
this.mounted = false;
}
- fetchLeaks = (visible /*: boolean */) => {
- if (visible && this.state.leaks == null) {
- getApplicationLeak(this.props.component.key).then(
+ fetchLeaks = (visible: boolean) => {
+ if (visible && this.state.leaks) {
+ getApplicationLeak(this.props.component).then(
leaks => {
if (this.mounted) {
this.setState({ leaks });
diff --git a/server/sonar-web/src/main/js/apps/overview/components/OverviewApp.tsx b/server/sonar-web/src/main/js/apps/overview/components/OverviewApp.tsx
index a9bba4a81bc..5bc3679f9df 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/OverviewApp.tsx
+++ b/server/sonar-web/src/main/js/apps/overview/components/OverviewApp.tsx
@@ -143,7 +143,9 @@ export class OverviewApp extends React.PureComponent<Props, State> {
};
getApplicationLeakPeriod = () =>
- this.state.measures.find(measure => measure.metric.key === 'new_bugs') ? { index: 1 } : null;
+ this.state.measures.find(measure => measure.metric.key === 'new_bugs')
+ ? { index: 1 }
+ : undefined;
renderLoading() {
return (
diff --git a/server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.js b/server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.tsx
index cd504227511..ee95828e890 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.js
+++ b/server/sonar-web/src/main/js/apps/overview/components/__tests__/ApplicationLeakPeriodLegend-test.tsx
@@ -17,13 +17,12 @@
* 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 * as React from 'react';
import { shallow } from 'enzyme';
import ApplicationLeakPeriodLegend from '../ApplicationLeakPeriodLegend';
it('renders', () => {
- const wrapper = shallow(<ApplicationLeakPeriodLegend component={{ key: 'foo' }} />);
+ const wrapper = shallow(<ApplicationLeakPeriodLegend component="foo" />);
expect(wrapper).toMatchSnapshot();
wrapper.setState({
leaks: [
diff --git a/server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.js.snap b/server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.tsx.snap
index cb842597822..cb842597822 100644
--- a/server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.js.snap
+++ b/server/sonar-web/src/main/js/apps/overview/components/__tests__/__snapshots__/ApplicationLeakPeriodLegend-test.tsx.snap
diff --git a/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.js b/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx
index d7a1db69ffa..d6433a10e08 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/BugsAndVulnerabilities.tsx
@@ -17,9 +17,9 @@
* 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 * as React from 'react';
import { Link } from 'react-router';
-import enhance from './enhance';
+import enhance, { ComposedProps } from './enhance';
import ApplicationLeakPeriodLegend from '../components/ApplicationLeakPeriodLegend';
import BubblesIcon from '../../../components/icons-components/BubblesIcon';
import BugIcon from '../../../components/icons-components/BugIcon';
@@ -29,7 +29,7 @@ import { getMetricName } from '../helpers/metrics';
import { getComponentDrilldownUrl } from '../../../helpers/urls';
import { translate } from '../../../helpers/l10n';
-class BugsAndVulnerabilities extends React.PureComponent {
+export class BugsAndVulnerabilities extends React.PureComponent<ComposedProps> {
renderHeader() {
const { branch, component } = this.props;
@@ -55,15 +55,14 @@ class BugsAndVulnerabilities extends React.PureComponent {
renderLeak() {
const { component, leakPeriod } = this.props;
-
- if (leakPeriod == null) {
+ if (!leakPeriod) {
return null;
}
return (
<div className="overview-domain-leak">
{component.qualifier === 'APP' ? (
- <ApplicationLeakPeriodLegend component={component} />
+ <ApplicationLeakPeriodLegend component={component.key} />
) : (
<LeakPeriodLegend period={leakPeriod} />
)}
@@ -130,7 +129,7 @@ class BugsAndVulnerabilities extends React.PureComponent {
render() {
const { measures } = this.props;
const bugsMeasure = measures.find(measure => measure.metric.key === 'bugs');
- if (bugsMeasure == null) {
+ if (!bugsMeasure) {
return null;
}
return (
diff --git a/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.js b/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx
index 94786fea4f8..ac7fcd0c94c 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/CodeSmells.tsx
@@ -17,46 +17,35 @@
* 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 * as React from 'react';
import { Link } from 'react-router';
-import enhance from './enhance';
-import Tooltip from '../../../components/controls/Tooltip';
+import enhance, { ComposedProps } from './enhance';
import DateFromNow from '../../../components/intl/DateFromNow';
-import DateTimeFormatter from '../../../components/intl/DateTimeFormatter';
import { getMetricName } from '../helpers/metrics';
import { translate, translateWithParameters } from '../../../helpers/l10n';
import { formatMeasure, isDiffMetric } from '../../../helpers/measures';
import { getComponentIssuesUrl } from '../../../helpers/urls';
import CodeSmellIcon from '../../../components/icons-components/CodeSmellIcon';
-class CodeSmells extends React.PureComponent {
+export class CodeSmells extends React.PureComponent<ComposedProps> {
renderHeader() {
return this.props.renderHeader('Maintainability', translate('metric.code_smells.name'));
}
- renderDebt(metric, type) {
+ renderDebt(metric: string, type: string) {
const { branch, measures, component } = this.props;
const measure = measures.find(measure => measure.metric.key === metric);
- const value = this.props.getValue(measure);
+ const value = measure ? this.props.getValue(measure) : undefined;
const params = { branch, resolved: 'false', facetMode: 'effort', types: type };
if (isDiffMetric(metric)) {
Object.assign(params, { sinceLeakPeriod: 'true' });
}
- const tooltip = (
- <DateTimeFormatter date={component.analysisDate}>
- {formattedAnalysisDate => (
- <span>{translateWithParameters('widget.as_calculated_on_x', formattedAnalysisDate)}</span>
- )}
- </DateTimeFormatter>
- );
return (
- <Tooltip overlay={tooltip} placement="top">
- <Link to={getComponentIssuesUrl(component.key, params)}>
- {formatMeasure(value, 'SHORT_WORK_DUR')}
- </Link>
- </Tooltip>
+ <Link to={getComponentIssuesUrl(component.key, params)}>
+ {formatMeasure(value, 'SHORT_WORK_DUR')}
+ </Link>
);
}
@@ -75,7 +64,7 @@ class CodeSmells extends React.PureComponent {
);
}
- renderTimeline(range, displayDate) {
+ renderTimeline(range: string, displayDate?: boolean) {
return this.props.renderTimeline(
'sqale_index',
range,
@@ -85,8 +74,7 @@ class CodeSmells extends React.PureComponent {
renderLeak() {
const { leakPeriod } = this.props;
-
- if (leakPeriod == null) {
+ if (!leakPeriod) {
return null;
}
@@ -152,7 +140,7 @@ class CodeSmells extends React.PureComponent {
render() {
const { measures } = this.props;
const codeSmellsMeasure = measures.find(measure => measure.metric.key === 'code_smells');
- if (codeSmellsMeasure == null) {
+ if (!codeSmellsMeasure) {
return null;
}
return (
diff --git a/server/sonar-web/src/main/js/apps/overview/main/Coverage.js b/server/sonar-web/src/main/js/apps/overview/main/Coverage.tsx
index 6d800e2a8f6..cd1abc807ee 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/Coverage.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/Coverage.tsx
@@ -17,36 +17,25 @@
* 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 enhance from './enhance';
+import * as React from 'react';
+import enhance, { ComposedProps } from './enhance';
import DrilldownLink from '../../../components/shared/DrilldownLink';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure, getPeriodValue } from '../../../helpers/measures';
import { translate } from '../../../helpers/l10n';
import CoverageRating from '../../../components/ui/CoverageRating';
-class Coverage extends React.PureComponent {
+export class Coverage extends React.PureComponent<ComposedProps> {
getCoverage() {
- const { measures } = this.props;
- const { value } = measures.find(measure => measure.metric.key === 'coverage');
- return Number(value);
- }
-
- getNewCoverageMeasure() {
- const { measures } = this.props;
- return measures.find(measure => measure.metric.key === 'new_coverage');
- }
-
- getNewLinesToCover() {
- const { measures } = this.props;
- return measures.find(measure => measure.metric.key === 'new_lines_to_cover');
+ const measure = this.props.measures.find(measure => measure.metric.key === 'coverage');
+ return Number(measure ? measure.value : undefined);
}
renderHeader() {
return this.props.renderHeader('Coverage', translate('metric.coverage.name'));
}
- renderTimeline(range) {
+ renderTimeline(range: string) {
return this.props.renderTimeline('coverage', range);
}
@@ -62,7 +51,7 @@ class Coverage extends React.PureComponent {
return (
<div className="overview-domain-measure">
<div className="display-inline-block text-middle big-spacer-right">
- <CoverageRating value={coverage} size="big" />
+ <CoverageRating size="big" value={coverage} />
</div>
<div className="display-inline-block text-middle">
@@ -84,19 +73,16 @@ class Coverage extends React.PureComponent {
}
renderNewCoverage() {
- const { branch, component, leakPeriod } = this.props;
- const newCoverageMeasure = this.getNewCoverageMeasure();
- const newLinesToCover = this.getNewLinesToCover();
-
- const newCoverageValue = newCoverageMeasure
- ? getPeriodValue(newCoverageMeasure, leakPeriod.index)
- : null;
- const newLinesToCoverValue = newLinesToCover
- ? getPeriodValue(newLinesToCover, leakPeriod.index)
- : null;
+ const { branch, component, leakPeriod, measures } = this.props;
+ if (!leakPeriod) {
+ return null;
+ }
+ const newCoverageMeasure = measures.find(measure => measure.metric.key === 'new_coverage');
+ const newCoverageValue =
+ newCoverageMeasure && getPeriodValue(newCoverageMeasure, leakPeriod.index);
const formattedValue =
- newCoverageValue != null ? (
+ newCoverageMeasure && newCoverageValue !== undefined ? (
<div>
<DrilldownLink
branch={branch}
@@ -110,8 +96,12 @@ class Coverage extends React.PureComponent {
) : (
<span>—</span>
);
+
+ const newLinesToCover = measures.find(measure => measure.metric.key === 'new_lines_to_cover');
+ const newLinesToCoverValue =
+ newLinesToCover && getPeriodValue(newLinesToCover, leakPeriod.index);
const label =
- newLinesToCoverValue != null && newLinesToCoverValue > 0 ? (
+ newLinesToCover && newLinesToCoverValue !== undefined && Number(newLinesToCoverValue) > 0 ? (
<div className="overview-domain-measure-label">
{translate('overview.coverage_on')}
<br />
@@ -129,6 +119,7 @@ class Coverage extends React.PureComponent {
) : (
<div className="overview-domain-measure-label">{getMetricName('new_coverage')}</div>
);
+
return (
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">{formattedValue}</div>
@@ -152,7 +143,7 @@ class Coverage extends React.PureComponent {
renderLeak() {
const { leakPeriod } = this.props;
- if (leakPeriod == null) {
+ if (!leakPeriod) {
return null;
}
return (
@@ -167,7 +158,7 @@ class Coverage extends React.PureComponent {
render() {
const { measures } = this.props;
const coverageMeasure = measures.find(measure => measure.metric.key === 'coverage');
- if (coverageMeasure == null) {
+ if (!coverageMeasure) {
return null;
}
return (
diff --git a/server/sonar-web/src/main/js/apps/overview/main/Duplications.js b/server/sonar-web/src/main/js/apps/overview/main/Duplications.tsx
index 3f94296f6b3..d8a09caee40 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/Duplications.js
+++ b/server/sonar-web/src/main/js/apps/overview/main/Duplications.tsx
@@ -17,20 +17,20 @@
* 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 enhance from './enhance';
+import * as React from 'react';
+import enhance, { ComposedProps } from './enhance';
import DrilldownLink from '../../../components/shared/DrilldownLink';
import { getMetricName } from '../helpers/metrics';
import { formatMeasure, getPeriodValue } from '../../../helpers/measures';
import { translate } from '../../../helpers/l10n';
import DuplicationsRating from '../../../components/ui/DuplicationsRating';
-class Duplications extends React.PureComponent {
+export class Duplications extends React.PureComponent<ComposedProps> {
renderHeader() {
return this.props.renderHeader('Duplications', translate('overview.domain.duplications'));
}
- renderTimeline(range) {
+ renderTimeline(range: string) {
return this.props.renderTimeline('duplicated_lines_density', range);
}
@@ -40,13 +40,18 @@ class Duplications extends React.PureComponent {
renderDuplications() {
const { branch, component, measures } = this.props;
+
const measure = measures.find(measure => measure.metric.key === 'duplicated_lines_density');
+ if (!measure) {
+ return null;
+ }
+
const duplications = Number(measure.value);
return (
<div className="overview-domain-measure">
<div className="display-inline-block text-middle big-spacer-right">
- <DuplicationsRating value={duplications} size="big" />
+ <DuplicationsRating size="big" value={duplications} />
</div>
<div className="display-inline-block text-middle">
@@ -70,20 +75,17 @@ class Duplications extends React.PureComponent {
renderNewDuplications() {
const { branch, component, measures, leakPeriod } = this.props;
+ if (!leakPeriod) {
+ return null;
+ }
+
const newDuplicationsMeasure = measures.find(
measure => measure.metric.key === 'new_duplicated_lines_density'
);
- const newLinesMeasure = measures.find(measure => measure.metric.key === 'new_lines');
-
- const newDuplicationsValue = newDuplicationsMeasure
- ? getPeriodValue(newDuplicationsMeasure, leakPeriod.index)
- : null;
- const newLinesValue = newLinesMeasure
- ? getPeriodValue(newLinesMeasure, leakPeriod.index)
- : null;
-
+ const newDuplicationsValue =
+ newDuplicationsMeasure && getPeriodValue(newDuplicationsMeasure, leakPeriod.index);
const formattedValue =
- newDuplicationsValue != null ? (
+ newDuplicationsMeasure && newDuplicationsValue ? (
<div>
<DrilldownLink
branch={branch}
@@ -97,8 +99,11 @@ class Duplications extends React.PureComponent {
) : (
<span>—</span>
);
+
+ const newLinesMeasure = measures.find(measure => measure.metric.key === 'new_lines');
+ const newLinesValue = newLinesMeasure && getPeriodValue(newLinesMeasure, leakPeriod.index);
const label =
- newLinesValue != null && newLinesValue > 0 ? (
+ newLinesMeasure && newLinesValue !== undefined && Number(newLinesValue) > 0 ? (
<div className="overview-domain-measure-label">
{translate('overview.duplications_on')}
<br />
@@ -116,6 +121,7 @@ class Duplications extends React.PureComponent {
) : (
<div className="overview-domain-measure-label">{getMetricName('new_duplications')}</div>
);
+
return (
<div className="overview-domain-measure">
<div className="overview-domain-measure-value">{formattedValue}</div>
diff --git a/server/sonar-web/src/main/js/apps/overview/main/enhance.tsx b/server/sonar-web/src/main/js/apps/overview/main/enhance.tsx
index 43e23c1715d..2b07c3c9239 100644
--- a/server/sonar-web/src/main/js/apps/overview/main/enhance.tsx
+++ b/server/sonar-web/src/main/js/apps/overview/main/enhance.tsx
@@ -21,7 +21,6 @@ import * as React from 'react';
import { Link } from 'react-router';
import DrilldownLink from '../../../components/shared/DrilldownLink';
import BubblesIcon from '../../../components/icons-components/BubblesIcon';
-import DateTimeFormatter from '../../../components/intl/DateTimeFormatter';
import HistoryIcon from '../../../components/icons-components/HistoryIcon';
import Rating from '../../../components/ui/Rating';
import Timeline from '../components/Timeline';
@@ -34,7 +33,7 @@ import {
getRatingTooltip,
MeasureEnhanced
} from '../../../helpers/measures';
-import { translateWithParameters, getLocalizedMetricName } from '../../../helpers/l10n';
+import { getLocalizedMetricName } from '../../../helpers/l10n';
import { getPeriodDate } from '../../../helpers/periods';
import {
getComponentDrilldownUrl,
@@ -155,22 +154,10 @@ export default function enhance(ComposedComponent: React.ComponentType<ComposedP
Object.assign(params, { sinceLeakPeriod: 'true' });
}
- const tooltip = component.analysisDate && (
- <DateTimeFormatter date={component.analysisDate}>
- {formattedAnalysisDate => (
- <span>
- {translateWithParameters('widget.as_calculated_on_x', formattedAnalysisDate)}
- </span>
- )}
- </DateTimeFormatter>
- );
-
return (
- <Tooltip overlay={tooltip} placement="top">
- <Link to={getComponentIssuesUrl(component.key, params)}>
- {formatMeasure(value, 'SHORT_INT')}
- </Link>
- </Tooltip>
+ <Link to={getComponentIssuesUrl(component.key, params)}>
+ {formatMeasure(value, 'SHORT_INT')}
+ </Link>
);
};
@@ -209,9 +196,9 @@ export default function enhance(ComposedComponent: React.ComponentType<ComposedP
getValue={this.getValue}
renderHeader={this.renderHeader}
renderHistoryLink={this.renderHistoryLink}
+ renderIssues={this.renderIssues}
renderMeasure={this.renderMeasure}
renderRating={this.renderRating}
- renderIssues={this.renderIssues}
renderTimeline={this.renderTimeline}
/>
);