import React, { useState } from "react"; import { useTranslation } from "react-i18next"; import { AlertVariant, Button, ButtonVariant, Label, PageSection, ToolbarItem, } from "@patternfly/react-core"; import { InfoCircleIcon } from "@patternfly/react-icons"; import UserRepresentation from "keycloak-admin/lib/defs/userRepresentation"; import { useAdminClient } from "../context/auth/AdminClient"; import { ViewHeader } from "../components/view-header/ViewHeader"; import { DataList } from "../components/table-toolbar/DataList"; import { useAlerts } from "../components/alert/Alerts"; export const UsersSection = () => { const { t } = useTranslation("users"); const adminClient = useAdminClient(); const { addAlert } = useAlerts(); const [key, setKey] = useState(""); const refresh = () => setKey(`${new Date().getTime()}`); const loader = async (first?: number, max?: number, search?: string) => { const params: { [name: string]: string | number } = { first: first!, max: max!, }; if (search) { params.search = search; } return await adminClient.users.find({ ...params }); }; const deleteUser = async (user: UserRepresentation) => { try { await adminClient.users.del({ id: user.id! }); refresh(); addAlert(t("userDeletedSuccess"), AlertVariant.success); } catch (error) { addAlert(t("userDeletedError", { error }), AlertVariant.danger); } }; const StatusRow = (user: UserRepresentation) => { return ( <> {!user.enabled && ( )} ); }; return ( <> } actions={[ { title: t("common:delete"), onRowClick: (user) => { deleteUser(user); }, }, ]} columns={[ { name: "username", displayKey: "users:username", }, { name: "email", displayKey: "users:email", }, { name: "lastName", displayKey: "users:lastName", }, { name: "firstName", displayKey: "users:firstName", }, { name: "status", displayKey: "users:status", cellRenderer: StatusRow, }, ]} /> ); };