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
|
/*
* 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 React from 'react';
import { Navigate, Route, useParams, useSearchParams } from 'react-router-dom';
import NavigateWithParams from '../../app/utils/NavigateWithParams';
import { omitNil } from '../../helpers/request';
import { searchParamsToQuery } from '../../helpers/urls';
import App from './components/App';
const routes = () => (
<Route path="component_measures">
<Route index={true} element={<App />} />
<Route
path="domain/:domainName"
element={
<NavigateWithParams
pathname="/component_measures"
transformParams={(params) =>
omitNil({
metric: params['domainName'],
})
}
/>
}
/>
<Route path="metric/:metricKey" element={<MetricRedirect />} />
<Route path="metric/:metricKey/:view" element={<MetricRedirect />} />
</Route>
);
function MetricRedirect() {
const params = useParams();
const [searchParams] = useSearchParams();
if (params.view === 'history') {
const to = {
pathname: '/project/activity',
search: new URLSearchParams(
omitNil({
id: searchParams.get('id') ?? undefined,
graph: 'custom',
custom_metrics: params.metricKey,
})
).toString(),
};
return <Navigate to={to} replace={true} />;
}
const to = {
pathname: '/component_measures',
search: new URLSearchParams(
omitNil({
...searchParamsToQuery(searchParams),
metric: params.metricKey,
view: params.view,
})
).toString(),
};
return <Navigate to={to} replace={true} />;
}
export default routes;
|