2022-02-09 14:39:10 +00:00
|
|
|
import React from "react";
|
|
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
import { useForm } from "react-hook-form";
|
|
|
|
import {
|
|
|
|
AlertVariant,
|
|
|
|
Button,
|
|
|
|
Form,
|
|
|
|
FormGroup,
|
|
|
|
TextInput,
|
|
|
|
} from "@patternfly/react-core";
|
|
|
|
import { CheckIcon, PencilAltIcon, TimesIcon } from "@patternfly/react-icons";
|
|
|
|
|
|
|
|
import type CredentialRepresentation from "@keycloak/keycloak-admin-client/lib/defs/credentialRepresentation";
|
|
|
|
import { useAdminClient } from "../../context/auth/AdminClient";
|
|
|
|
import { useAlerts } from "../../components/alert/Alerts";
|
|
|
|
|
|
|
|
type UserLabelForm = {
|
|
|
|
userLabel: string;
|
|
|
|
};
|
|
|
|
|
|
|
|
type InlineLabelEditProps = {
|
|
|
|
userId: string;
|
|
|
|
credential: CredentialRepresentation;
|
|
|
|
isEditable: boolean;
|
|
|
|
toggle: () => void;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const InlineLabelEdit = ({
|
|
|
|
userId,
|
|
|
|
credential,
|
|
|
|
isEditable,
|
|
|
|
toggle,
|
|
|
|
}: InlineLabelEditProps) => {
|
|
|
|
const { t } = useTranslation("users");
|
|
|
|
const { register, handleSubmit } = useForm<UserLabelForm>();
|
|
|
|
|
|
|
|
const adminClient = useAdminClient();
|
|
|
|
const { addAlert, addError } = useAlerts();
|
|
|
|
|
|
|
|
const saveUserLabel = async (userLabel: UserLabelForm) => {
|
|
|
|
try {
|
|
|
|
await adminClient.users.updateCredentialLabel(
|
|
|
|
{
|
|
|
|
id: userId,
|
|
|
|
credentialId: credential.id!,
|
|
|
|
},
|
|
|
|
userLabel.userLabel || ""
|
|
|
|
);
|
|
|
|
addAlert(t("updateCredentialUserLabelSuccess"), AlertVariant.success);
|
|
|
|
toggle();
|
|
|
|
} catch (error) {
|
|
|
|
addError("users:updateCredentialUserLabelError", error);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Form isHorizontal className="kc-form-userLabel">
|
|
|
|
<FormGroup fieldId="kc-userLabel" className="kc-userLabel-row">
|
|
|
|
<div className="kc-form-group-userLabel">
|
|
|
|
{isEditable ? (
|
|
|
|
<>
|
|
|
|
<TextInput
|
|
|
|
name="userLabel"
|
2022-03-07 14:32:34 +00:00
|
|
|
data-testid="userLabelFld"
|
2022-02-09 14:39:10 +00:00
|
|
|
defaultValue={credential.userLabel}
|
|
|
|
ref={register()}
|
|
|
|
type="text"
|
|
|
|
className="kc-userLabel"
|
|
|
|
aria-label={t("userLabel")}
|
|
|
|
/>
|
|
|
|
<div className="kc-userLabel-actionBtns">
|
|
|
|
<Button
|
2022-03-07 14:32:34 +00:00
|
|
|
data-testid="editUserLabelAcceptBtn"
|
2022-02-09 14:39:10 +00:00
|
|
|
variant="link"
|
2022-03-07 14:32:34 +00:00
|
|
|
className="kc-editUserLabelAcceptBtn"
|
2022-02-09 14:39:10 +00:00
|
|
|
onClick={() => {
|
|
|
|
handleSubmit(saveUserLabel)();
|
|
|
|
}}
|
|
|
|
icon={<CheckIcon />}
|
|
|
|
/>
|
|
|
|
<Button
|
2022-03-07 14:32:34 +00:00
|
|
|
data-testid="editUserLabelCancelBtn"
|
2022-02-09 14:39:10 +00:00
|
|
|
variant="link"
|
|
|
|
className="kc-editUserLabel-cancelBtn"
|
|
|
|
onClick={toggle}
|
|
|
|
icon={<TimesIcon />}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
) : (
|
|
|
|
<>
|
|
|
|
{credential.userLabel}
|
|
|
|
<Button
|
|
|
|
variant="link"
|
|
|
|
className="kc-editUserLabel-btn"
|
|
|
|
onClick={toggle}
|
|
|
|
data-testid="editUserLabelBtn"
|
|
|
|
icon={<PencilAltIcon />}
|
|
|
|
/>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</FormGroup>
|
|
|
|
</Form>
|
|
|
|
);
|
|
|
|
};
|