2022-11-10 10:46:23 +01:00
|
|
|
import {
|
2022-12-06 09:05:49 +01:00
|
|
|
Navigate,
|
2022-11-10 10:46:23 +01:00
|
|
|
Route,
|
|
|
|
Routes,
|
|
|
|
useLocation,
|
|
|
|
useNavigate,
|
|
|
|
} from 'react-router-dom';
|
|
|
|
import { ITab, VerticalTabs } from 'component/common/VerticalTabs/VerticalTabs';
|
|
|
|
import { ProjectAccess } from 'component/project/ProjectAccess/ProjectAccess';
|
|
|
|
import ProjectEnvironmentList from 'component/project/ProjectEnvironment/ProjectEnvironment';
|
|
|
|
import { ChangeRequestConfiguration } from './ChangeRequestConfiguration/ChangeRequestConfiguration';
|
2023-02-21 14:27:46 +01:00
|
|
|
import { ProjectApiAccess } from 'component/project/Project/ProjectSettings/ProjectApiAccess/ProjectApiAccess';
|
2023-03-17 09:23:27 +01:00
|
|
|
import { ProjectSegments } from './ProjectSegments/ProjectSegments';
|
2023-05-05 13:32:44 +02:00
|
|
|
import { ProjectDefaultStrategySettings } from './ProjectDefaultStrategySettings/ProjectDefaultStrategySettings';
|
2023-07-11 08:47:38 +02:00
|
|
|
import { Settings } from './Settings/Settings';
|
|
|
|
import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig';
|
2023-08-07 18:13:56 +02:00
|
|
|
import { EnterpriseBadge } from 'component/common/EnterpriseBadge/EnterpriseBadge';
|
|
|
|
import { Box } from '@mui/material';
|
2022-11-10 10:46:23 +01:00
|
|
|
|
|
|
|
export const ProjectSettings = () => {
|
|
|
|
const location = useLocation();
|
2023-08-07 18:13:56 +02:00
|
|
|
const { uiConfig, isPro, isEnterprise } = useUiConfig();
|
2022-11-10 10:46:23 +01:00
|
|
|
const navigate = useNavigate();
|
|
|
|
|
2023-08-07 18:13:56 +02:00
|
|
|
const updatedNavigation = uiConfig.flags?.frontendNavigationUpdate;
|
|
|
|
|
2022-12-06 09:05:49 +01:00
|
|
|
const tabs: ITab[] = [
|
2023-07-11 08:47:38 +02:00
|
|
|
...(uiConfig.flags.newProjectLayout
|
|
|
|
? [
|
|
|
|
{
|
|
|
|
id: '',
|
|
|
|
label: 'Settings',
|
|
|
|
},
|
|
|
|
]
|
|
|
|
: []),
|
2022-12-06 09:05:49 +01:00
|
|
|
{
|
|
|
|
id: 'environments',
|
|
|
|
label: 'Environments',
|
|
|
|
},
|
2023-08-07 18:13:56 +02:00
|
|
|
...(!updatedNavigation || isPro() || isEnterprise()
|
|
|
|
? [
|
|
|
|
{
|
|
|
|
id: 'access',
|
|
|
|
label: 'Access',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'segments',
|
|
|
|
label: 'Segments',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'change-requests',
|
|
|
|
label: 'Change request configuration',
|
|
|
|
icon:
|
|
|
|
isPro() && updatedNavigation ? (
|
|
|
|
<Box sx={{ marginLeft: 'auto' }}>
|
|
|
|
<EnterpriseBadge />
|
|
|
|
</Box>
|
|
|
|
) : undefined,
|
|
|
|
},
|
|
|
|
]
|
|
|
|
: []),
|
2023-03-30 09:22:45 +02:00
|
|
|
{
|
2023-02-07 12:01:45 +01:00
|
|
|
id: 'api-access',
|
|
|
|
label: 'API access',
|
2023-03-30 09:22:45 +02:00
|
|
|
},
|
2023-06-28 10:38:21 +02:00
|
|
|
{
|
2023-05-05 13:32:44 +02:00
|
|
|
id: 'default-strategy',
|
|
|
|
label: 'Default strategy',
|
2023-06-28 10:38:21 +02:00
|
|
|
},
|
|
|
|
];
|
2023-05-05 13:32:44 +02:00
|
|
|
|
2022-11-10 10:46:23 +01:00
|
|
|
const onChange = (tab: ITab) => {
|
|
|
|
navigate(tab.id);
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<VerticalTabs
|
|
|
|
tabs={tabs}
|
|
|
|
value={
|
|
|
|
tabs.find(
|
|
|
|
({ id }) => id && location.pathname?.includes(`/${id}`)
|
|
|
|
)?.id || tabs[0].id
|
|
|
|
}
|
|
|
|
onChange={onChange}
|
|
|
|
>
|
|
|
|
<Routes>
|
2023-07-11 08:47:38 +02:00
|
|
|
{uiConfig.flags.newProjectLayout ? (
|
|
|
|
<Route path="/*" element={<Settings />} />
|
|
|
|
) : null}
|
2022-11-10 10:46:23 +01:00
|
|
|
<Route
|
2022-12-06 09:05:49 +01:00
|
|
|
path="environments/*"
|
2022-11-10 10:46:23 +01:00
|
|
|
element={<ProjectEnvironmentList />}
|
|
|
|
/>
|
2022-12-06 09:05:49 +01:00
|
|
|
<Route path="access/*" element={<ProjectAccess />} />
|
2023-03-17 09:23:27 +01:00
|
|
|
<Route path="segments/*" element={<ProjectSegments />} />
|
2022-11-10 10:46:23 +01:00
|
|
|
<Route
|
2022-12-06 09:05:49 +01:00
|
|
|
path="change-requests/*"
|
2022-11-10 10:46:23 +01:00
|
|
|
element={<ChangeRequestConfiguration />}
|
|
|
|
/>
|
2023-03-30 09:22:45 +02:00
|
|
|
<Route path="api-access/*" element={<ProjectApiAccess />} />
|
2023-06-28 10:38:21 +02:00
|
|
|
<Route
|
|
|
|
path="default-strategy/*"
|
|
|
|
element={<ProjectDefaultStrategySettings />}
|
|
|
|
/>
|
2022-11-10 10:46:23 +01:00
|
|
|
<Route
|
|
|
|
path="*"
|
|
|
|
element={<Navigate replace to={tabs[0].id} />}
|
|
|
|
/>
|
|
|
|
</Routes>
|
|
|
|
</VerticalTabs>
|
|
|
|
);
|
|
|
|
};
|