import React, { useMemo, useState } from "react"; import { AlertVariant, Button, ButtonVariant, Divider, Flex, FlexItem, PageSection, Radio, Title, ToolbarItem, } from "@patternfly/react-core"; import "./RealmSettingsSection.css"; import { ListEmptyState } from "../components/list-empty-state/ListEmptyState"; import { KeycloakDataTable } from "../components/table-toolbar/KeycloakDataTable"; import { useTranslation } from "react-i18next"; import { useAdminClient } from "../context/auth/AdminClient"; import { upperCaseFormatter } from "../util"; import { CodeEditor, Language } from "@patternfly/react-code-editor"; import { Link } from "react-router-dom"; import type ClientPolicyRepresentation from "@keycloak/keycloak-admin-client/lib/defs/clientPolicyRepresentation"; import { useConfirmDialog } from "../components/confirm-dialog/ConfirmDialog"; import { useAlerts } from "../components/alert/Alerts"; export const PoliciesTab = () => { const { t } = useTranslation("realm-settings"); const adminClient = useAdminClient(); const { addAlert, addError } = useAlerts(); const [show, setShow] = useState(false); const [policies, setPolicies] = useState([]); const [selectedPolicy, setSelectedPolicy] = useState(); const loader = async () => { const policies = await adminClient.clientPolicies.listPolicies(); setPolicies(policies.policies!); return policies.policies!; }; const code = useMemo(() => JSON.stringify(policies, null, 2), [policies]); const [toggleDeleteDialog, DeleteConfirm] = useConfirmDialog({ titleKey: t("deleteClientPolicyConfirmTitle"), messageKey: t("deleteClientPolicyConfirm", { policyName: selectedPolicy?.name, }), continueButtonLabel: t("delete"), continueButtonVariant: ButtonVariant.danger, onConfirm: async () => { try { // delete client policy here addAlert(t("deleteClientPolicySuccess"), AlertVariant.success); } catch (error) { addError(t("deleteClientPolicyError"), error); } }, }); return ( <> {t("policiesConfigType")} setShow(false)} label={t("policiesConfigTypes.formView")} id="formView-radioBtn" className="kc-form-radio-btn pf-u-mr-sm pf-u-ml-sm" /> setShow(true)} label={t("policiesConfigTypes.jsonEditor")} id="jsonEditor-radioBtn" className="kc-editor-radio-btn" /> {!show ? ( } ariaLabelKey="identity-providers:mappersList" searchPlaceholderKey="realm-settings:clientPolicySearch" isPaginated loader={loader} toolbarItem={ } actions={[ { title: t("common:delete"), onRowClick: (item) => { toggleDeleteDialog(); setSelectedPolicy(item); }, }, ]} columns={[ { name: "name", displayKey: "common:name", }, { name: "enabled", displayKey: "common:enabled", cellFormatters: [upperCaseFormatter()], }, { name: "description", displayKey: "common:description", }, ]} /> ) : ( <>
)} ); };