From 239ba944a3613d090119afecaa0a77776ae0d11b Mon Sep 17 00:00:00 2001 From: iso9000t <119494473+iso9000t@users.noreply.github.com> Date: Thu, 21 Nov 2024 15:04:48 +0400 Subject: [PATCH] EPMRPP-96981 || Server Settings page layout (#4100) * EPMRPP-96981 || Server Settings page layout * EPMRPP-96981 || adjusted styles to match the Figma mockup * EPMRPP-96981 || fetch app info on mount * EPMRPP-96981 || refactor the hooks syntax * EPMRPP-96981 || address PR comments and update component styles * EPMRPP-96981 || Server Settings page layout * EPMRPP-96981 || adjusted styles to match the Figma mockup * EPMRPP-96981 || fetch app info on mount * EPMRPP-96981 || refactor the hooks syntax * EPMRPP-96981 || address PR comments and update component styles * EPMRPP-96981 || remove an unused file and add a constant * EPMRPP-96981 || refactor and update translations * EPMRPP-96981 || refactor the code --- app/localization/translated/be.json | 7 +- app/localization/translated/es.json | 7 +- app/localization/translated/ru.json | 7 +- app/localization/translated/uk.json | 7 +- app/localization/translated/zh.json | 7 +- app/src/controllers/appInfo/constants.js | 1 + app/src/controllers/appInfo/index.js | 1 + app/src/controllers/appInfo/selectors.js | 3 + .../authConfigurationTab.jsx | 2 + .../forms/githubAuthForm/githubAuthForm.scss | 2 +- .../authConfigurationTab/forms/index.js | 1 + .../forms/ssoUsersForm/index.js | 17 +++ .../forms/ssoUsersForm/ssoUsersForm.jsx | 119 ++++++++++++++++++ .../forms/ssoUsersForm/ssoUsersForm.scss | 81 ++++++++++++ 14 files changed, 256 insertions(+), 6 deletions(-) create mode 100644 app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/forms/ssoUsersForm/index.js create mode 100644 app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/forms/ssoUsersForm/ssoUsersForm.jsx create mode 100644 app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/forms/ssoUsersForm/ssoUsersForm.scss diff --git a/app/localization/translated/be.json b/app/localization/translated/be.json index 798e2d64af..5b44f35486 100644 --- a/app/localization/translated/be.json +++ b/app/localization/translated/be.json @@ -647,7 +647,8 @@ "EditWidgetModal.editWidgetSuccess": "Віджэт абноўлены!", "EditWidgetModal.headerText": "Рэдагаваць віджэт", "EmailFormFields.authLabel": "Аўтарызацыя", - "EmailFormFields.fromLabel": "Імя адпраўніка па змаўчанні", + "EmailFormFields.fromEmailLabel": "From Email", + "EmailFormFields.fromNameLabel": "From name", "EmailFormFields.hostLabel": "Хост", "EmailFormFields.passwordLabel": "Пароль", "EmailFormFields.portFieldHint": "Магчымы толькі лічбы ад '1' да '65535'", @@ -1839,6 +1840,10 @@ "SortingControl.sortByFailedItems": "Няўдалыя пункты", "SortingControl.sortByPassingRate": "Прахадны бал", "SortingControl.sortByTotal": "Агульная колькасць", + "SsoUsersForm.formHeader": "Instance Invitations", + "SsoUsersForm.manualInvitesDescription": "Карыстальнікі могуць адпраўляць запрашэнні іншым карыстальнікам. Калі ўключана, новыя карыстальнікі могуць быць ствараны толькі праз SSO.", + "SsoUsersForm.ssoOnlyDescription": "Новыя карыстальнікі могуць быць створаны толькі праз SSO.", + "SsoUsersForm.switcherLabel": "Толькі SSO карыстальнікі", "StackTrace.jumpTo": "Перайсці", "StackTrace.linkText": "Адкрыць логі", "StackTrace.loadLabel": "Загрузіць яшчэ", diff --git a/app/localization/translated/es.json b/app/localization/translated/es.json index a94647513c..986849dd33 100644 --- a/app/localization/translated/es.json +++ b/app/localization/translated/es.json @@ -647,7 +647,8 @@ "EditWidgetModal.editWidgetSuccess": "¡Widget actualizado!", "EditWidgetModal.headerText": "Editar widget", "EmailFormFields.authLabel": "Autorización", - "EmailFormFields.fromLabel": "Nombre del remitente predeterminado", + "EmailFormFields.fromEmailLabel": "From Email", + "EmailFormFields.fromNameLabel": "From name", "EmailFormFields.hostLabel": "Host", "EmailFormFields.passwordLabel": "Contraseña", "EmailFormFields.portFieldHint": "Solo se permiten números del '1' al '65535'", @@ -1839,6 +1840,10 @@ "SortingControl.sortByFailedItems": "Elementos fallidos", "SortingControl.sortByPassingRate": "Porcentaje de aprobados", "SortingControl.sortByTotal": "Cantidad total", + "SsoUsersForm.formHeader": "Instance Invitations", + "SsoUsersForm.manualInvitesDescription": "Users can manually send invitations for other users. If enabled new users can be created via SSO only.", + "SsoUsersForm.ssoOnlyDescription": "New users can be created via SSO only.", + "SsoUsersForm.switcherLabel": "SSO users only", "StackTrace.jumpTo": "Ir a", "StackTrace.linkText": "Abrir registros", "StackTrace.loadLabel": "Cargar más", diff --git a/app/localization/translated/ru.json b/app/localization/translated/ru.json index 22a9fd9425..daa7dd0749 100644 --- a/app/localization/translated/ru.json +++ b/app/localization/translated/ru.json @@ -647,7 +647,8 @@ "EditWidgetModal.editWidgetSuccess": "Виджет обновлен!", "EditWidgetModal.headerText": "Редактировать виджет", "EmailFormFields.authLabel": "Авторизация", - "EmailFormFields.fromLabel": "Имя отправителя по умолчанию", + "EmailFormFields.fromEmailLabel": "From Email", + "EmailFormFields.fromNameLabel": "From name", "EmailFormFields.hostLabel": "Хост", "EmailFormFields.passwordLabel": "Пароль", "EmailFormFields.portFieldHint": "Возможны только цифры от '1' до '65535'", @@ -1839,6 +1840,10 @@ "SortingControl.sortByFailedItems": "Неудачные пункты", "SortingControl.sortByPassingRate": "Проходной балл", "SortingControl.sortByTotal": "Общее количество", + "SsoUsersForm.formHeader": "Instance Invitations", + "SsoUsersForm.manualInvitesDescription": "Пользователи могут вручную отправлять приглашения другим пользователям. Если включено, новых пользователей можно создавать только через SSO.", + "SsoUsersForm.ssoOnlyDescription": "Новых пользователей можно создавать только через SSO.", + "SsoUsersForm.switcherLabel": "Только SSO пользователи", "StackTrace.jumpTo": "Перейти", "StackTrace.linkText": "Открыть логи", "StackTrace.loadLabel": "Загрузить еще", diff --git a/app/localization/translated/uk.json b/app/localization/translated/uk.json index c645efe9dd..d34ca3e9da 100644 --- a/app/localization/translated/uk.json +++ b/app/localization/translated/uk.json @@ -647,7 +647,8 @@ "EditWidgetModal.editWidgetSuccess": "Оновлений Віджет!", "EditWidgetModal.headerText": "Віджет Редагувати", "EmailFormFields.authLabel": "Авторизація", - "EmailFormFields.fromLabel": "Ім’я відправника за замовчуванням", + "EmailFormFields.fromEmailLabel": "From Email", + "EmailFormFields.fromNameLabel": "From name", "EmailFormFields.hostLabel": "Хост", "EmailFormFields.passwordLabel": "Пароль", "EmailFormFields.portFieldHint": "Можливі тільки цифри від '1' до '65535'", @@ -1839,6 +1840,10 @@ "SortingControl.sortByFailedItems": "Невдалі пункти", "SortingControl.sortByPassingRate": "Прохідний бал", "SortingControl.sortByTotal": "Загальна кількість", + "SsoUsersForm.formHeader": "Instance Invitations", + "SsoUsersForm.manualInvitesDescription": "Користувачі можуть самостійно надсилати запрошення іншим користувачам. Якщо ввімкнено, нові користувачі створюються виключно через SSO.", + "SsoUsersForm.ssoOnlyDescription": "Користувачі створюються виключно через SSO.", + "SsoUsersForm.switcherLabel": "SSO users only", "StackTrace.jumpTo": "Перейти", "StackTrace.linkText": "Логи Відкрити", "StackTrace.loadLabel": "Завантажити", diff --git a/app/localization/translated/zh.json b/app/localization/translated/zh.json index 2ba04d183e..71b13c1360 100644 --- a/app/localization/translated/zh.json +++ b/app/localization/translated/zh.json @@ -647,7 +647,8 @@ "EditWidgetModal.editWidgetSuccess": "小部件已更新", "EditWidgetModal.headerText": "编辑小部件", "EmailFormFields.authLabel": "授权", - "EmailFormFields.fromLabel": "默认发件人姓名", + "EmailFormFields.fromEmailLabel": "From Email", + "EmailFormFields.fromNameLabel": "From name", "EmailFormFields.hostLabel": "服务器(Host)", "EmailFormFields.passwordLabel": "密码", "EmailFormFields.portFieldHint": "只允许输入从“1”到“65535”的数字", @@ -1839,6 +1840,10 @@ "SortingControl.sortByFailedItems": "失败的测试项", "SortingControl.sortByPassingRate": "通过率", "SortingControl.sortByTotal": "全部", + "SsoUsersForm.formHeader": "Instance Invitations", + "SsoUsersForm.manualInvitesDescription": "Users can manually send invitations for other users. If enabled new users can be created via SSO only.", + "SsoUsersForm.ssoOnlyDescription": "New users can be created via SSO only.", + "SsoUsersForm.switcherLabel": "SSO users only", "StackTrace.jumpTo": "跳转至", "StackTrace.linkText": "在日志视图中打开", "StackTrace.loadLabel": "加载更多", diff --git a/app/src/controllers/appInfo/constants.js b/app/src/controllers/appInfo/constants.js index cbd0668eda..8f77bdbc71 100644 --- a/app/src/controllers/appInfo/constants.js +++ b/app/src/controllers/appInfo/constants.js @@ -17,6 +17,7 @@ export const APP_INFO_NAMESPACE = 'appInfo'; export const ANALYTICS_INSTANCE_KEY = 'server.details.instance'; export const ANALYTICS_ALL_KEY = 'server.analytics.all'; +export const SSO_USERS_ONLY_KEY = 'server.users.sso'; export const OLD_HISTORY_KEY = 'history_old'; export const GA_MEASUREMENT_ID = 'ga_measurement_id'; export const INSTANCE_TYPE = 'instance_type'; diff --git a/app/src/controllers/appInfo/index.js b/app/src/controllers/appInfo/index.js index 13b135d71c..76722080b9 100644 --- a/app/src/controllers/appInfo/index.js +++ b/app/src/controllers/appInfo/index.js @@ -29,5 +29,6 @@ export { isDemoInstanceSelector, areUserSuggestionsAllowedSelector, baseEventParametersSelector, + ssoUsersOnlySelector, } from './selectors'; export { ANALYTICS_ALL_KEY } from './constants'; diff --git a/app/src/controllers/appInfo/selectors.js b/app/src/controllers/appInfo/selectors.js index e19a3c4ad7..2cce1ff98d 100644 --- a/app/src/controllers/appInfo/selectors.js +++ b/app/src/controllers/appInfo/selectors.js @@ -31,6 +31,7 @@ import { NOT_PROVIDED, ALLOW_DELETE_ACCOUNT, USER_SUGGESTIONS, + SSO_USERS_ONLY_KEY, } from './constants'; export const appInfoSelector = (state) => state.appInfo || {}; @@ -57,6 +58,8 @@ export const analyticsEnabledSelector = (state) => extensionsConfigSelector(state)[ANALYTICS_ALL_KEY] === 'true'; export const analyzerExtensionsSelector = (state) => extensionsSelector(state).analyzers || []; export const authExtensionsSelector = (state) => uatInfoSelector(state).authExtensions || {}; +export const ssoUsersOnlySelector = (state) => + extensionsConfigSelector(state)[SSO_USERS_ONLY_KEY] === 'true'; export const isOldHistorySelector = (state) => environmentSelector(state)[OLD_HISTORY_KEY] === 'true'; export const isDemoInstanceSelector = (state) => !!apiJobsSelector(state).flushingDataTrigger; diff --git a/app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/authConfigurationTab.jsx b/app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/authConfigurationTab.jsx index d19f22b93e..ae0d996bb0 100644 --- a/app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/authConfigurationTab.jsx +++ b/app/src/pages/admin/serverSettingsPage/serverSettingsTabs/authConfigurationTab/authConfigurationTab.jsx @@ -16,6 +16,7 @@ import classNames from 'classnames/bind'; import { GithubAuthForm } from './forms'; +import { SsoUsersForm } from './forms/ssoUsersForm'; import styles from './authConfigurationTab.scss'; const cx = classNames.bind(styles); @@ -23,5 +24,6 @@ const cx = classNames.bind(styles); export const AuthConfigurationTab = () => (