import { Navigate, 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'; import { ProjectApiAccess } from 'component/project/Project/ProjectSettings/ProjectApiAccess/ProjectApiAccess'; import { ProjectSegments } from './ProjectSegments/ProjectSegments'; import { ProjectDefaultStrategySettings } from './ProjectDefaultStrategySettings/ProjectDefaultStrategySettings'; import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig'; export const ProjectSettings = () => { const location = useLocation(); const navigate = useNavigate(); const { uiConfig } = useUiConfig(); const { strategyImprovements } = uiConfig.flags; const tabs: ITab[] = [ { id: 'environments', label: 'Environments', }, { id: 'access', label: 'Access', }, { id: 'segments', label: 'Segments', }, { id: 'change-requests', label: 'Change request configuration', }, { id: 'api-access', label: 'API access', }, ]; if (Boolean(strategyImprovements)) { tabs.push({ id: 'default-strategy', label: 'Default strategy', }); } const onChange = (tab: ITab) => { navigate(tab.id); }; return ( id && location.pathname?.includes(`/${id}`) )?.id || tabs[0].id } onChange={onChange} > } /> } /> } /> } /> } /> {Boolean(strategyImprovements) && ( } /> )} } /> ); };