import React, { useState } from "react"; import { DescriptionList } from "@patternfly/react-core"; import type ResourceServerRepresentation from "@keycloak/keycloak-admin-client/lib/defs/resourceServerRepresentation"; import { KeycloakSpinner } from "../../components/keycloak-spinner/KeycloakSpinner"; import { useAdminClient, useFetch } from "../../context/auth/AdminClient"; import { DetailDescription, DetailDescriptionLink } from "./DetailDescription"; import { toScopeDetails } from "../routes/Scope"; import { useRealm } from "../../context/realm-context/RealmContext"; import { toPermissionDetails } from "../routes/PermissionDetails"; import "./detail-cell.css"; type Scope = { id: string; name: string }[]; type DetailCellProps = { id: string; clientId: string; uris?: string[]; }; export const DetailCell = ({ id, clientId, uris }: DetailCellProps) => { const { adminClient } = useAdminClient(); const { realm } = useRealm(); const [scope, setScope] = useState(); const [permissions, setPermissions] = useState(); useFetch( () => Promise.all([ adminClient.clients.listScopesByResource({ id: clientId, resourceName: id, }), adminClient.clients.listPermissionsByResource({ id: clientId, resourceId: id, }), ]), ([scopes, permissions]) => { setScope(scopes); setPermissions(permissions); }, [] ); if (!permissions || !scope) { return ; } return ( s.name} link={(scope) => toScopeDetails({ id: clientId, realm, scopeId: scope.id! }) } /> p.name!} link={(permission) => toPermissionDetails({ id: clientId, realm, permissionId: permission.id!, permissionType: "resource", }) } /> ); };