aboutsummaryrefslogtreecommitdiffstats
path: root/server/sonar-web/src/main/js/apps/quality-profiles/details/ProfileExporters.js
blob: 2d387eff92c87b51312a1089780b66da4c52c549 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/*
 * 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 { stringify } from 'querystring';
import React from 'react';
import { translate } from '../../../helpers/l10n';
import type { Profile, Exporter } from '../propTypes';

type Props = {
  exporters: Array<Exporter>,
  organization: ?string,
  profile: Profile
};

export default class ProfileExporters extends React.PureComponent {
  props: Props;

  getExportUrl(exporter: Exporter) {
    const { organization, profile } = this.props;

    const path = '/api/qualityprofiles/export';
    const parameters: { [string]: string } = {
      exporterKey: exporter.key,
      language: profile.language,
      name: profile.name
    };
    if (organization) {
      Object.assign(parameters, { organization });
    }
    return window.baseUrl + path + '?' + stringify(parameters);
  }

  render() {
    const { exporters, profile } = this.props;
    const exportersForLanguage = exporters.filter(e => e.languages.includes(profile.language));

    if (exportersForLanguage.length === 0) {
      return null;
    }

    return (
      <div className="quality-profile-box quality-profile-exporters">
        <header className="big-spacer-bottom">
          <h2>
            {translate('quality_profiles.exporters')}
          </h2>
        </header>
        <ul>
          {exportersForLanguage.map(exporter =>
            <li key={exporter.key} data-key={exporter.key} className="spacer-top">
              <a href={this.getExportUrl(exporter)} target="_blank">
                {exporter.name}
              </a>
            </li>
          )}
        </ul>
      </div>
    );
  }
}