From 2f64f4326673044c3d8ea2a8ddf74c5e6e8c5627 Mon Sep 17 00:00:00 2001 From: Erik Jan de Wit Date: Fri, 25 Oct 2024 15:24:09 +0200 Subject: [PATCH] required can have a value that is a boolean when used with controls (#34251) * required is a boolean when used with controls fixes: #33614 Signed-off-by: Erik Jan de Wit * simplified rules declaration Signed-off-by: Erik Jan de Wit * added missing messages Signed-off-by: Erik Jan de Wit * use value when it's present Signed-off-by: Erik Jan de Wit --------- Signed-off-by: Erik Jan de Wit --- .../ProviderBaseAdvancedSettingsPage.ts | 2 +- .../authentication/components/EditFlow.tsx | 2 +- .../components/ExecutionConfigModal.tsx | 2 +- .../components/modals/AddSubFlowModal.tsx | 2 +- .../authentication/form/NameDescription.tsx | 2 +- .../authentication/policies/CibaPolicy.tsx | 10 +- .../policies/WebauthnPolicy.tsx | 2 +- .../client-scopes/details/MappingDetails.tsx | 2 +- .../src/client-scopes/details/ScopeForm.tsx | 5 +- .../src/clients/ClientDescription.tsx | 2 +- .../add/OIDCAuthentication.tsx | 118 ++++-------------- .../src/realm-settings/NewClientPolicy.tsx | 2 +- .../user-profile/AttributesGroupForm.tsx | 5 +- .../attribute/AddTranslationsDialog.tsx | 5 +- .../ldap/LdapSettingsSearching.tsx | 2 +- .../src/controls/PasswordControl.tsx | 3 +- .../ui-shared/src/controls/TextControl.tsx | 4 +- 17 files changed, 43 insertions(+), 127 deletions(-) diff --git a/js/apps/admin-ui/cypress/support/pages/admin-ui/manage/identity_providers/ProviderBaseAdvancedSettingsPage.ts b/js/apps/admin-ui/cypress/support/pages/admin-ui/manage/identity_providers/ProviderBaseAdvancedSettingsPage.ts index e3622fe1b8e2..07694558515d 100644 --- a/js/apps/admin-ui/cypress/support/pages/admin-ui/manage/identity_providers/ProviderBaseAdvancedSettingsPage.ts +++ b/js/apps/admin-ui/cypress/support/pages/admin-ui/manage/identity_providers/ProviderBaseAdvancedSettingsPage.ts @@ -84,7 +84,7 @@ export default class ProviderBaseGeneralSettingsPage extends PageObject { #jwksUrl = "config.jwksUrl"; #pkceSwitch = "#config\\.pkceEnabled"; #pkceMethod = "#pkceMethod"; - #clientAuth = "#clientAuthentication"; + #clientAuth = "#clientAuthMethod"; #clientAssertionSigningAlg = "#clientAssertionSigningAlg"; #clientAssertionAudienceInput = "#clientAssertionAudience"; #jwtX509HeadersSwitch = "#jwtX509HeadersEnabled"; diff --git a/js/apps/admin-ui/src/authentication/components/EditFlow.tsx b/js/apps/admin-ui/src/authentication/components/EditFlow.tsx index 210884dedc6e..06d71f22c4d6 100644 --- a/js/apps/admin-ui/src/authentication/components/EditFlow.tsx +++ b/js/apps/admin-ui/src/authentication/components/EditFlow.tsx @@ -84,7 +84,7 @@ export const EditFlow = ({ execution, onRowChange }: EditFlowProps) => { name="displayName" label={t("name")} labelIcon={t("flowNameHelp")} - rules={{ required: { value: true, message: t("required") } }} + rules={{ required: t("required") }} /> { name="alias" label={t("name")} labelIcon={t("flowNameHelp")} - rules={{ required: { value: true, message: t("required") } }} + rules={{ required: t("required") }} /> { value: CIBA_EXPIRES_IN_MAX, message: t("lessThan", { value: CIBA_EXPIRES_IN_MAX }), }, - required: { - value: true, - message: t("required"), - }, + required: t("required"), }} /> { value: CIBA_INTERVAL_MAX, message: t("lessThan", { value: CIBA_INTERVAL_MAX }), }, - required: { - value: true, - message: t("required"), - }, + required: t("required"), }} /> { label={t("name")} labelIcon={t("scopeNameHelp")} rules={{ - required: { - value: true, - message: t("required"), - }, + required: t("required"), onChange: (e) => { if (isDynamicScopesEnabled) setDynamicRegex(e.target.validated, true); diff --git a/js/apps/admin-ui/src/clients/ClientDescription.tsx b/js/apps/admin-ui/src/clients/ClientDescription.tsx index 967f41c8c862..95722f9c7a4e 100644 --- a/js/apps/admin-ui/src/clients/ClientDescription.tsx +++ b/js/apps/admin-ui/src/clients/ClientDescription.tsx @@ -19,7 +19,7 @@ export const ClientDescription = ({ name="clientId" label={t("clientId")} labelIcon={t("clientIdHelp")} - rules={{ required: { value: true, message: t("required") } }} + rules={{ required: t("required") }} /> { const { t } = useTranslation(); const { control } = useFormContext(); - const [openClientAuth, setOpenClientAuth] = useState(false); - const [openClientAuthSigAlg, setOpenClientAuthSigAlg] = useState(false); const clientAuthMethod = useWatch({ control: control, @@ -35,96 +27,34 @@ export const OIDCAuthentication = ({ create = true }: { create?: boolean }) => { return ( <> - - } - fieldId="clientAuthentication" - > - ( - setOpenClientAuth(!openClientAuth)} - onSelect={(value) => { - field.onChange(value as string); - setOpenClientAuth(false); - }} - selections={field.value} - variant={SelectVariant.single} - aria-label={t("clientAuthentication")} - isOpen={openClientAuth} - > - {clientAuthentications.map((option) => ( - - {t(`clientAuthentications.${option}`)} - - ))} - - )} - /> - + labelIcon={t("clientAuthenticationHelp")} + options={clientAuthentications.map((auth) => ({ + key: auth, + value: t(`clientAuthentications.${auth}`), + }))} + controller={{ + defaultValue: clientAuthentications[0], + }} + /> - - } - fieldId="clientAssertionSigningAlg" - > - ( - setOpenClientAuthSigAlg(!openClientAuthSigAlg)} - onSelect={(value) => { - field.onChange(value.toString()); - setOpenClientAuthSigAlg(false); - }} - selections={field.value || t("algorithmNotSpecified")} - variant={SelectVariant.single} - aria-label={t("selectClientAssertionSigningAlg")} - isOpen={openClientAuthSigAlg} - > - {[ - - {t("algorithmNotSpecified")} - , - ...sortProviders(providers).map((option) => ( - - {option} - - )), - ]} - - )} - /> - + labelIcon={t("clientAssertionSigningAlgHelp")} + options={[ + { key: "", value: t("algorithmNotSpecified") }, + ...sortProviders(providers).map((p) => ({ key: p, value: p })), + ]} + controller={{ + defaultValue: "", + }} + /> {(clientAuthMethod === "private_key_jwt" || clientAuthMethod === "client_secret_jwt") && ( policies.some((policy) => policy.name === value) ? t("createClientProfileNameHelperText").toString() diff --git a/js/apps/admin-ui/src/realm-settings/user-profile/AttributesGroupForm.tsx b/js/apps/admin-ui/src/realm-settings/user-profile/AttributesGroupForm.tsx index 8c55e63d7e3b..220bc22a7ea1 100644 --- a/js/apps/admin-ui/src/realm-settings/user-profile/AttributesGroupForm.tsx +++ b/js/apps/admin-ui/src/realm-settings/user-profile/AttributesGroupForm.tsx @@ -467,10 +467,7 @@ export default function AttributesGroupForm() { labelIcon={t("nameHintHelp")} isDisabled={!!matchingGroup || editMode} rules={{ - required: { - value: true, - message: t("required"), - }, + required: t("required"), onChange: (event) => { handleAttributesGroupNameChange(event, event.target.value); }, diff --git a/js/apps/admin-ui/src/realm-settings/user-profile/attribute/AddTranslationsDialog.tsx b/js/apps/admin-ui/src/realm-settings/user-profile/attribute/AddTranslationsDialog.tsx index 872c62c6b98f..5505be2e3cd9 100644 --- a/js/apps/admin-ui/src/realm-settings/user-profile/attribute/AddTranslationsDialog.tsx +++ b/js/apps/admin-ui/src/realm-settings/user-profile/attribute/AddTranslationsDialog.tsx @@ -332,10 +332,7 @@ export const AddTranslationsDialog = ({ label={t("translationValue")} data-testid={`translation-value-${rowIndex}`} rules={{ - required: { - value: true, - message: t("required"), - }, + required: t("required"), }} /> )} diff --git a/js/apps/admin-ui/src/user-federation/ldap/LdapSettingsSearching.tsx b/js/apps/admin-ui/src/user-federation/ldap/LdapSettingsSearching.tsx index 9498a0007e59..6a39c230cda5 100644 --- a/js/apps/admin-ui/src/user-federation/ldap/LdapSettingsSearching.tsx +++ b/js/apps/admin-ui/src/user-federation/ldap/LdapSettingsSearching.tsx @@ -41,7 +41,7 @@ export const LdapSettingsSearching = ({ controller={{ defaultValue: "", rules: { - required: { value: true, message: t("validateEditMode") }, + required: t("validateEditMode"), }, }} options={["", "READ_ONLY", "WRITABLE", "UNSYNCED"]} diff --git a/js/libs/ui-shared/src/controls/PasswordControl.tsx b/js/libs/ui-shared/src/controls/PasswordControl.tsx index 13c53ab64dd0..e866e4094dec 100644 --- a/js/libs/ui-shared/src/controls/PasswordControl.tsx +++ b/js/libs/ui-shared/src/controls/PasswordControl.tsx @@ -11,6 +11,7 @@ import { UseControllerProps, useController, } from "react-hook-form"; +import { getRuleValue } from "../utils/getRuleValue"; import { FormLabel } from "./FormLabel"; import { PasswordInput, PasswordInputProps } from "./PasswordInput"; @@ -32,7 +33,7 @@ export const PasswordControl = < props: PasswordControlProps, ) => { const { labelIcon, ...rest } = props; - const required = !!props.rules?.required; + const required = !!getRuleValue(props.rules?.required); const defaultValue = props.defaultValue ?? ("" as PathValue); const { field, fieldState } = useController({ diff --git a/js/libs/ui-shared/src/controls/TextControl.tsx b/js/libs/ui-shared/src/controls/TextControl.tsx index 668ec2868b9f..5d4d9eede02a 100644 --- a/js/libs/ui-shared/src/controls/TextControl.tsx +++ b/js/libs/ui-shared/src/controls/TextControl.tsx @@ -14,7 +14,7 @@ import { UseControllerProps, useController, } from "react-hook-form"; - +import { getRuleValue } from "../utils/getRuleValue"; import { FormLabel } from "./FormLabel"; export type TextControlProps< @@ -36,7 +36,7 @@ export const TextControl = < props: TextControlProps, ) => { const { labelIcon, helperText, ...rest } = props; - const required = !!props.rules?.required; + const required = !!getRuleValue(props.rules?.required); const defaultValue = props.defaultValue ?? ("" as PathValue); const { field, fieldState } = useController({