import styled from '@emotion/styled'; import { Trans, useLingui } from '@lingui/react/macro'; import { H2Title, IconLock, Section, Tag } from 'twenty-ui'; import { isMultiWorkspaceEnabledState } from '@/client-config/states/isMultiWorkspaceEnabledState'; import { SettingsPageContainer } from '@/settings/components/SettingsPageContainer'; import { SettingsSSOIdentitiesProvidersListCard } from '@/settings/security/components/SSO/SettingsSSOIdentitiesProvidersListCard'; import { SettingsSecurityAuthProvidersOptionsList } from '@/settings/security/components/SettingsSecurityAuthProvidersOptionsList'; import { SettingsApprovedAccessDomainsListCard } from '@/settings/security/components/approvedAccessDomains/SettingsApprovedAccessDomainsListCard'; import { ToggleImpersonate } from '@/settings/workspace/components/ToggleImpersonate'; import { SettingsPath } from '@/types/SettingsPath'; import { SubMenuTopBarContainer } from '@/ui/layout/page/components/SubMenuTopBarContainer'; import { useIsFeatureEnabled } from '@/workspace/hooks/useIsFeatureEnabled'; import { useRecoilValue } from 'recoil'; import { FeatureFlagKey } from '~/generated/graphql'; import { getSettingsPath } from '~/utils/navigation/getSettingsPath'; const StyledContainer = styled.div` width: 100%; `; const StyledMainContent = styled.div` display: flex; flex-direction: column; gap: ${({ theme }) => theme.spacing(10)}; min-height: 200px; `; const StyledSection = styled(Section)` flex-shrink: 0; `; export const SettingsSecurity = () => { const { t } = useLingui(); const isMultiWorkspaceEnabled = useRecoilValue(isMultiWorkspaceEnabledState); const IsApprovedAccessDomainsEnabled = useIsFeatureEnabled( FeatureFlagKey.IsApprovedAccessDomainsEnabled, ); return ( Workspace, href: getSettingsPath(SettingsPath.Workspace), }, { children: Security }, ]} > } /> {IsApprovedAccessDomainsEnabled && ( )}
{isMultiWorkspaceEnabled && (
)}
); };