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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
|
/*
* SonarQube
* Copyright (C) 2009-2022 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 * as React from 'react';
import { FormattedMessage } from 'react-intl';
import {
getEdition,
getEditionDownloadFilename,
getEditionDownloadUrl
} from '../../helpers/editions';
import { translate, translateWithParameters } from '../../helpers/l10n';
import { EditionKey } from '../../types/editions';
import { SystemUpgrade } from '../../types/system';
import DateFormatter from '../intl/DateFormatter';
import SystemUpgradeIntermediate from './SystemUpgradeIntermediate';
export interface SystemUpgradeItemProps {
edition: EditionKey | undefined;
isLTSVersion: boolean;
isPatch: boolean;
systemUpgrades: SystemUpgrade[];
}
export default function SystemUpgradeItem(props: SystemUpgradeItemProps) {
const { edition, isPatch, isLTSVersion, systemUpgrades } = props;
const lastUpgrade = systemUpgrades[0];
const downloadUrl = getEditionDownloadUrl(
getEdition(edition || EditionKey.community),
lastUpgrade
);
let header = translate('system.latest_version');
if (isLTSVersion) {
header = translate('system.lts_version');
} else if (isPatch) {
header = translate('system.latest_patch');
}
return (
<div className="system-upgrade-version it__upgrade-list-item">
<h3 className="h1 spacer-bottom">
<strong>{header}</strong>
{!isPatch && (
<a
className="spacer-left medium"
href="https://www.sonarqube.org/whats-new/?referrer=sonarqube"
rel="noopener noreferrer"
target="_blank">
{translate('system.see_whats_new')}
</a>
)}
</h3>
<p>
<FormattedMessage
defaultMessage={translate('system.version_is_availble')}
id="system.version_is_availble"
values={{ version: <b>SonarQube {lastUpgrade.version}</b> }}
/>
</p>
<p className="spacer-top">{lastUpgrade.description}</p>
<div className="big-spacer-top">
{lastUpgrade.releaseDate && (
<DateFormatter date={lastUpgrade.releaseDate} long={true}>
{formattedDate => (
<span>{translateWithParameters('system.released_x', formattedDate)}</span>
)}
</DateFormatter>
)}
{lastUpgrade.changeLogUrl && (
<a
className="spacer-left"
href={lastUpgrade.changeLogUrl}
rel="noopener noreferrer"
target="_blank">
{translate('system.release_notes')}
</a>
)}
</div>
<SystemUpgradeIntermediate className="spacer-top" upgrades={systemUpgrades.slice(1)} />
<div className="big-spacer-top">
<a
className="button"
download={getEditionDownloadFilename(downloadUrl)}
href={downloadUrl}
rel="noopener noreferrer"
target="_blank">
{translateWithParameters('system.download_x', lastUpgrade.version)}
</a>
<a
className="spacer-left"
href="https://redirect.sonarsource.com/doc/upgrading.html"
rel="noopener noreferrer"
target="_blank">
{translate('system.how_to_upgrade')}
</a>
</div>
</div>
);
}
|