added update email button (#22361)

fixes: #20902
This commit is contained in:
Erik Jan de Wit 2023-08-11 08:00:39 +02:00 committed by GitHub
parent 6db0bc5428
commit cd24896de1
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 9 deletions

View file

@ -153,6 +153,7 @@
"unShareSuccess": "Resource successfully un-shared.",
"update": "Update",
"updateCredAriaLabel": "Update credential",
"updateEmail": "Update email",
"updateError": "Could not update the resource due to: {{error}}",
"updateSuccess": "Resource successfully updated.",
"user": "User",

View file

@ -1,11 +1,20 @@
import { FormGroup, Select, SelectOption } from "@patternfly/react-core";
import {
Button,
FormGroup,
InputGroup,
Select,
SelectOption,
} from "@patternfly/react-core";
import { ExternalLinkSquareAltIcon } from "@patternfly/react-icons";
import { get } from "lodash-es";
import { useState } from "react";
import { Controller, useFormContext } from "react-hook-form";
import { useTranslation } from "react-i18next";
import { KeycloakTextInput } from "ui-shared";
import { UserProfileAttributeMetadata } from "../api/representations";
import { environment } from "../environment";
import { TFuncKey } from "../i18n";
import { keycloak } from "../keycloak";
import { LocaleSelector } from "./LocaleSelector";
import { fieldName, isBundleKey, unWrap } from "./PersonalInfo";
@ -26,6 +35,13 @@ export const FormField = ({ attribute }: FormFieldProps) => {
const isSelect = (attribute: UserProfileAttributeMetadata) =>
Object.hasOwn(attribute.validators, "options");
const {
updateEmailFeatureEnabled,
updateEmailActionEnabled,
isRegistrationEmailAsUsername,
isEditUserNameAllowed,
} = environment.features;
if (attribute.name === "locale") return <LocaleSelector />;
return (
<FormGroup
@ -81,14 +97,33 @@ export const FormField = ({ attribute }: FormFieldProps) => {
)}
/>
) : (
<KeycloakTextInput
data-testid={attribute.name}
id={attribute.name}
isDisabled={attribute.readOnly}
{...register(fieldName(attribute.name), {
required: { value: attribute.required, message: t("required") },
})}
/>
<InputGroup>
<KeycloakTextInput
data-testid={attribute.name}
id={attribute.name}
isDisabled={
attribute.readOnly ||
(attribute.name === "email" && !updateEmailActionEnabled)
}
{...register(fieldName(attribute.name), {
required: { value: attribute.required, message: t("required") },
})}
/>
{attribute.name === "email" &&
updateEmailFeatureEnabled &&
updateEmailActionEnabled &&
(!isRegistrationEmailAsUsername || isEditUserNameAllowed) && (
<Button
id="update-email-btn"
variant="link"
onClick={() => keycloak.login({ action: "UPDATE_EMAIL" })}
icon={<ExternalLinkSquareAltIcon />}
iconPosition="right"
>
{t("updateEmail")}
</Button>
)}
</InputGroup>
)}
</FormGroup>
);