diff --git a/packages/console/src/ds-components/RadioGroup/Radio.tsx b/packages/console/src/ds-components/RadioGroup/Radio.tsx index 37f2068a1..3e56c7ef7 100644 --- a/packages/console/src/ds-components/RadioGroup/Radio.tsx +++ b/packages/console/src/ds-components/RadioGroup/Radio.tsx @@ -10,9 +10,11 @@ import styles from './Radio.module.scss'; function Check() { return ( - + + + diff --git a/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/ConfigForm.tsx b/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/ConfigForm.tsx index 7bc13d9bd..5ed0c7307 100644 --- a/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/ConfigForm.tsx +++ b/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/ConfigForm.tsx @@ -1,3 +1,4 @@ +/* eslint-disable max-lines */ import { type Application, type SsoConnectorWithProviderConfig, @@ -178,7 +179,14 @@ function ConfigForm({ )} options={applications.map((application) => ({ value: application.id, - title: `${application.name} (${application.type}, ID: ${application.id})`, + title: ( + + {application.name} + + ({t(`guide.categories.${application.type}`)}, ID: {application.id}) + + + ), }))} value={value} error={emptyApplicationsError ?? errors.config?.defaultApplicationId?.message} @@ -215,7 +223,7 @@ function ConfigForm({ }_title` )} -
+
{t( `enterprise_sso_details.idp_initiated_auth_config.auto_authentication_${ value ? 'enabled' : 'disabled' @@ -315,3 +323,4 @@ function ConfigForm({ } export default ConfigForm; +/* eslint-enable max-lines */ diff --git a/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/index.module.scss b/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/index.module.scss index e70e8d7a0..7a18c5f28 100644 --- a/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/index.module.scss +++ b/packages/console/src/pages/EnterpriseSsoDetails/IdpInitiatedAuth/index.module.scss @@ -9,14 +9,23 @@ } } +.applicationDetails { + margin-inline-start: _.unit(2); + color: var(--color-text-secondary); +} + .radioCardTitle { font: var(--font-label-2); + padding-inline-end: _.unit(5); margin-bottom: _.unit(2); } +.radioCardBody { + color: var(--color-text-secondary); +} + .radioCardFooter { margin-top: _.unit(4); - font: var(--font-body-3); color: var(--color-text-secondary); } @@ -30,8 +39,6 @@ } } -div[class$='disabled'] { - .radioCardFooter { - color: var(--color-disabled); - } +div[class*='radio'][class*='disabled'] { + color: inherit; } diff --git a/packages/console/src/pages/EnterpriseSsoDetails/index.tsx b/packages/console/src/pages/EnterpriseSsoDetails/index.tsx index ea2def54a..8ca96b2dc 100644 --- a/packages/console/src/pages/EnterpriseSsoDetails/index.tsx +++ b/packages/console/src/pages/EnterpriseSsoDetails/index.tsx @@ -16,7 +16,7 @@ import Skeleton from '@/components/DetailsPage/Skeleton'; import Drawer from '@/components/Drawer'; import PageMeta from '@/components/PageMeta'; import { EnterpriseSsoDetailsTabs } from '@/consts'; -import { isCloud } from '@/consts/env'; +import { isCloud, isDevFeaturesEnabled } from '@/consts/env'; import { SubscriptionDataContext } from '@/contexts/SubscriptionDataProvider'; import ConfirmModal from '@/ds-components/ConfirmModal'; import DynamicT from '@/ds-components/DynamicT'; @@ -69,6 +69,7 @@ function EnterpriseSsoDetails() { const isIdpInitiatedAuthConfigEnabled = useMemo( () => + isDevFeaturesEnabled && isCloud && ssoConnector?.providerType === SsoProviderType.SAML && currentSubscriptionQuota.idpInitiatedSsoEnabled, diff --git a/packages/phrases/src/locales/en/translation/admin-console/enterprise-sso-details.ts b/packages/phrases/src/locales/en/translation/admin-console/enterprise-sso-details.ts index 84fba50ee..1ea67aa10 100644 --- a/packages/phrases/src/locales/en/translation/admin-console/enterprise-sso-details.ts +++ b/packages/phrases/src/locales/en/translation/admin-console/enterprise-sso-details.ts @@ -88,15 +88,14 @@ const enterprise_sso_details = { 'No applications found. Please add one in the Applications section.', empty_applications_placeholder: 'No applications', authentication_type: 'Authentication type', - auto_authentication_disabled_title: 'Redirect to client for SP-initiated SSO (Recommended)', + auto_authentication_disabled_title: 'Redirect to client for SP-initiated SSO', auto_authentication_disabled_description: - 'Redirect users to the client-side application to initiate a secure SP-initiated OIDC authentication. This will prevent the CSRF attack and increase the security of the authentication process.', + 'Recommended. Redirect users to the client-side application to initiate a secure SP-initiated OIDC authentication. This will prevent the CSRF attacks.', auto_authentication_enabled_title: 'Directly sign in using the IdP-initiated SSO', auto_authentication_enabled_description: - 'Sign in directly using IdP-initiated SSO authentication. After successful sign-in, users will be redirected to the specified Redirect URI with the authorization code. (Without state and PKCE validation)', - auto_authentication_disabled_app: - 'For traditional web applications and single-page applications (SPA)', - auto_authentication_enabled_app: 'For traditional web applications only', + 'After successful sign-in, users will be redirected to the specified Redirect URI with the authorization code (Without state and PKCE validation).', + auto_authentication_disabled_app: 'For traditional web app, single-page app (SPA)', + auto_authentication_enabled_app: 'For traditional web app', idp_initiated_auth_callback_uri: 'Client callback URI', idp_initiated_auth_callback_uri_tooltip: 'The client callback URI to initiate a SP-initiated SSO authentication flow. An ssoConnectorId will be appended to the URI as a query parameter. (e.g., https://your.domain/sso/callback?connectorId={{ssoConnectorId}})',