/* * SonarQube * Copyright (C) 2009-2023 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 { Histogram } from 'design-system'; import { sortBy } from 'lodash'; import * as React from 'react'; import withLanguagesContext from '../../app/components/languages/withLanguagesContext'; import { translate } from '../../helpers/l10n'; import { formatMeasure } from '../../helpers/measures'; import { Languages } from '../../types/languages'; import { MetricType } from '../../types/metrics'; export interface LanguageDistributionProps { distribution: string; languages: Languages; } const NUMBER_FORMAT_THRESHOLD = 1000; export function LanguageDistribution(props: LanguageDistributionProps) { const { distribution, languages } = props; let parsedDistribution = distribution.split(';').map((point) => { const tokens = point.split('='); return { language: tokens[0], lines: parseInt(tokens[1], 10) }; }); parsedDistribution = sortBy(parsedDistribution, (d) => -d.lines); const data = parsedDistribution.map((d) => d.lines); const yTicks = parsedDistribution .map((d) => getLanguageName(languages, d.language)) .map(cutLanguageName); const yTooltips = parsedDistribution.map((d) => d.lines > NUMBER_FORMAT_THRESHOLD ? formatMeasure(d.lines, MetricType.Integer) : '' ); const yValues = parsedDistribution.map((d) => formatMeasure(d.lines, MetricType.ShortInteger)); return ( ); } function getLanguageName(languages: Languages, langKey: string) { if (langKey === '') { return translate('unknown'); } const lang = languages[langKey]; return lang ? lang.name : langKey; } function cutLanguageName(name: string) { return name.length > 10 ? `${name.substr(0, 7)}...` : name; } export default withLanguagesContext(LanguageDistribution);