/* * SonarQube :: Web * 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 d3 from 'd3'; import React from 'react'; import { getMeasuresAndVariations } from '../../../api/measures'; import { DomainTimeline } from '../components/domain-timeline'; import { DomainTreemap } from '../components/domain-treemap'; import { DomainBubbleChart } from '../components/domain-bubble-chart'; import { CoverageSelectionMixin } from '../components/coverage-selection-mixin'; import { getPeriodLabel, getPeriodDate } from './../helpers/periods'; import { TooltipsMixin } from '../../../components/mixins/tooltips-mixin'; import { filterMetrics, filterMetricsForDomains } from '../helpers/metrics'; import { DomainLeakTitle } from '../main/components'; import { CHART_REVERSED_COLORS_RANGE_PERCENT } from '../../../helpers/constants'; import { CoverageMeasuresList } from '../components/coverage-measures-list'; import { translate } from '../../../helpers/l10n'; const TEST_DOMAINS = ['Tests', 'Tests (Integration)', 'Tests (Overall)']; export const CoverageMain = React.createClass({ mixins: [TooltipsMixin, CoverageSelectionMixin], getInitialState() { return { ready: false, leakPeriodLabel: getPeriodLabel(this.props.component.periods, this.props.leakPeriodIndex), leakPeriodDate: getPeriodDate(this.props.component.periods, this.props.leakPeriodIndex) }; }, componentDidMount() { this.requestMeasures().then(r => { let measures = this.getMeasuresValues(r, 'value'); let leak = this.getMeasuresValues(r, 'var' + this.props.leakPeriodIndex); this.setState({ ready: true, measures, leak, coverageMetricPrefix: this.getCoverageMetricPrefix(measures) }); }); }, getMeasuresValues (measures, fieldKey) { let values = {}; Object.keys(measures).forEach(measureKey => { values[measureKey] = measures[measureKey][fieldKey]; }); return values; }, getMetricsForDomain() { return this.props.metrics .filter(metric => TEST_DOMAINS.indexOf(metric.domain) !== -1) .map(metric => metric.key); }, getMetricsForTimeline() { return filterMetricsForDomains(this.props.metrics, TEST_DOMAINS); }, getAllMetricsForTimeline() { return filterMetrics(this.props.metrics); }, requestMeasures () { return getMeasuresAndVariations(this.props.component.key, this.getMetricsForDomain()); }, renderLoading () { return
{translate('overview.no_coverage')}