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 { Settings } from './Settings/Settings'; import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig'; export const ProjectSettings = () => { const location = useLocation(); const { uiConfig } = useUiConfig(); const navigate = useNavigate(); const tabs: ITab[] = [ ...(uiConfig.flags.newProjectLayout ? [ { id: '', label: 'Settings', }, ] : []), { 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', }, { 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} > {uiConfig.flags.newProjectLayout ? ( } /> ) : null} } /> } /> } /> } /> } /> } /> } /> ); };