@keycloak/keycloak-admin-ui 26.1.5 → 26.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/lib/.vite/manifest.json +51 -30
- package/lib/{CreateFlow-CJuPGQV2.js → CreateFlow-C8ou3z3D.js} +9 -9
- package/lib/{CreateFlow-CJuPGQV2.js.map → CreateFlow-C8ou3z3D.js.map} +1 -1
- package/lib/{DetailOrganization-BZxym2fM.js → DetailOrganization-ChDFPj6w.js} +33 -33
- package/lib/{DetailOrganization-BZxym2fM.js.map → DetailOrganization-ChDFPj6w.js.map} +1 -1
- package/lib/{ExecutorForm-DxyNT3T5.js → ExecutorForm-CqhYZ9zD.js} +58 -57
- package/lib/ExecutorForm-CqhYZ9zD.js.map +1 -0
- package/lib/FlowDetails-BYnrUM6B.js +9025 -0
- package/lib/FlowDetails-BYnrUM6B.js.map +1 -0
- package/lib/NewOrganization-IjGiIFRg.js +36 -0
- package/lib/{NewOrganization-CdgyibqF.js.map → NewOrganization-IjGiIFRg.js.map} +1 -1
- package/lib/PermissionConfigurationDetails-B_xt8b5a.js +702 -0
- package/lib/PermissionConfigurationDetails-B_xt8b5a.js.map +1 -0
- package/lib/{PermissionDetails-lynVHdOa.js → PermissionDetails-FszJtVpG.js} +60 -60
- package/lib/{PermissionDetails-lynVHdOa.js.map → PermissionDetails-FszJtVpG.js.map} +1 -1
- package/lib/RealmSection-BkVmYRIb.js +179 -0
- package/lib/RealmSection-BkVmYRIb.js.map +1 -0
- package/lib/ResourceDetails-Br81AEgO.js +226 -0
- package/lib/ResourceDetails-Br81AEgO.js.map +1 -0
- package/lib/{ScopeDetails-plfHXCXz.js → ScopeDetails-nDvWwhgg.js} +35 -35
- package/lib/{ScopeDetails-plfHXCXz.js.map → ScopeDetails-nDvWwhgg.js.map} +1 -1
- package/lib/ScopePicker-kvjSuh0C.js +85 -0
- package/lib/ScopePicker-kvjSuh0C.js.map +1 -0
- package/lib/authentication/components/AuthenticationProviderContext.d.ts +9 -0
- package/lib/authentication/components/FlowRow.d.ts +1 -0
- package/lib/authentication/components/FlowTitle.d.ts +5 -2
- package/lib/clients/add/SamlSignature.d.ts +1 -0
- package/lib/clients/authorization/ScopePicker.d.ts +5 -2
- package/lib/clients/authorization/policy/LogicSelector.d.ts +1 -1
- package/lib/clients/authorization/policy/NameDescription.d.ts +3 -2
- package/lib/clients/routes/PermissionConfigurationDetails.d.ts +10 -0
- package/lib/components/client/ClientSelect.d.ts +4 -2
- package/lib/components/dynamic/BooleanComponent.d.ts +1 -1
- package/lib/components/dynamic/DynamicComponents.d.ts +2 -1
- package/lib/components/dynamic/FileComponent.d.ts +1 -1
- package/lib/components/dynamic/GroupComponent.d.ts +1 -1
- package/lib/components/dynamic/IntComponent.d.ts +1 -1
- package/lib/components/dynamic/ListComponent.d.ts +1 -1
- package/lib/components/dynamic/MapComponent.d.ts +1 -1
- package/lib/components/dynamic/MultivaluedListComponent.d.ts +1 -1
- package/lib/components/dynamic/MultivaluedStringComponent.d.ts +1 -1
- package/lib/components/dynamic/NumberComponent.d.ts +1 -1
- package/lib/components/dynamic/PasswordComponent.d.ts +1 -1
- package/lib/components/dynamic/RoleComponent.d.ts +1 -1
- package/lib/components/dynamic/ScriptComponent.d.ts +1 -1
- package/lib/components/dynamic/StringComponent.d.ts +1 -1
- package/lib/components/dynamic/TextComponent.d.ts +1 -1
- package/lib/components/dynamic/UserProfileAttributeListComponent.d.ts +1 -1
- package/lib/components/dynamic/components.d.ts +1 -0
- package/lib/components/form/CodeEditor.d.ts +12 -0
- package/lib/components/role-mapping/AddRoleMappingModal.d.ts +3 -2
- package/lib/components/users/UserSelect.d.ts +1 -1
- package/lib/context/RecentRealms.d.ts +6 -2
- package/lib/i18n/i18n.d.ts +4 -0
- package/lib/{index-lFXE1rYJ.js → index-CRHbhwXr.js} +36043 -36047
- package/lib/{index-lFXE1rYJ.js.map → index-CRHbhwXr.js.map} +1 -1
- package/lib/index.d.ts +1 -2
- package/lib/keycloak-admin-ui.css +1 -1
- package/lib/keycloak-admin-ui.js +162 -163
- package/lib/organizations/IdentityProviderSelect.d.ts +1 -1
- package/lib/permissions-configuration/PermissionsConfigurationSection.d.ts +1 -0
- package/lib/permissions-configuration/permission-configuration/AssignedPolicies.d.ts +10 -0
- package/lib/permissions-configuration/permission-configuration/AuthorizationScopesDetails.d.ts +10 -0
- package/lib/permissions-configuration/permission-configuration/ExistingPoliciesDialog.d.ts +10 -0
- package/lib/permissions-configuration/permission-configuration/NewPermissionConfigurationDialog.d.ts +8 -0
- package/lib/permissions-configuration/permission-configuration/NewPermissionPolicyDialog.d.ts +13 -0
- package/lib/permissions-configuration/permission-configuration/PermissionConfigurationDetails.d.ts +1 -0
- package/lib/permissions-configuration/permission-configuration/PermissionsConfigurationTab.d.ts +5 -0
- package/lib/permissions-configuration/permission-evaluation/PermissionEvaluationResult.d.ts +6 -0
- package/lib/permissions-configuration/permission-evaluation/PermissionsEvaluationTab.d.ts +8 -0
- package/lib/permissions-configuration/resource-types/GroupSelect.d.ts +7 -0
- package/lib/permissions-configuration/resource-types/ResourceType.d.ts +11 -0
- package/lib/permissions-configuration/resource-types/RoleSelect.d.ts +6 -0
- package/lib/permissions-configuration/resource-types/SearchDropdown.d.ts +20 -0
- package/lib/permissions-configuration/routes/NewPermissionConfiguration.d.ts +9 -0
- package/lib/permissions-configuration/routes/NewPermissionPolicy.d.ts +9 -0
- package/lib/permissions-configuration/routes/PermissionConfigurationDetails.d.ts +10 -0
- package/lib/permissions-configuration/routes/PermissionPolicyDetails.d.ts +10 -0
- package/lib/permissions-configuration/routes/PermissionsConfiguration.d.ts +7 -0
- package/lib/permissions-configuration/routes/PermissionsConfigurationTabs.d.ts +10 -0
- package/lib/permissions-configuration/routes/PermissionsPolicies.d.ts +8 -0
- package/lib/realm/RealmRoutes.d.ts +7 -0
- package/lib/realm/RealmSection.d.ts +5 -0
- package/lib/realm/add/NewRealmForm.d.ts +5 -1
- package/lib/realm-settings/themes/ThemesTab.d.ts +1 -0
- package/lib/utils/useIsFeatureEnabled.d.ts +2 -1
- package/lib/utils/useSortedResourceTypes.d.ts +5 -0
- package/package.json +26 -37
- package/lib/ExecutorForm-DxyNT3T5.js.map +0 -1
- package/lib/FlowDetails-ChnCh0MX.js +0 -10786
- package/lib/FlowDetails-ChnCh0MX.js.map +0 -1
- package/lib/NewOrganization-CdgyibqF.js +0 -36
- package/lib/ResourceDetails-BBY9AcKD.js +0 -286
- package/lib/ResourceDetails-BBY9AcKD.js.map +0 -1
- package/lib/browser-ponyfill-CTSSxZf6.js +0 -342
- package/lib/browser-ponyfill-CTSSxZf6.js.map +0 -1
- package/lib/components/realm-selector/RealmSelector.d.ts +0 -1
- package/lib/permissions/PermissionsSection.d.ts +0 -1
- package/lib/permissions/routes/Permissions.d.ts +0 -7
- package/lib/permissions/routes/PermissionsTabs.d.ts +0 -9
- package/lib/realm/routes/AddRealm.d.ts +0 -7
- /package/lib/{permissions → permissions-configuration}/routes.d.ts +0 -0
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ScopeDetails-
|
1
|
+
{"version":3,"file":"ScopeDetails-nDvWwhgg.js","sources":["../src/clients/authorization/ScopeDetails.tsx"],"sourcesContent":["import type ScopeRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/scopeRepresentation\";\nimport { TextControl, useAlerts, useFetch } from \"@keycloak/keycloak-ui-shared\";\nimport {\n ActionGroup,\n AlertVariant,\n Button,\n ButtonVariant,\n DropdownItem,\n PageSection,\n} from \"@patternfly/react-core\";\nimport { useState } from \"react\";\nimport { FormProvider, useForm } from \"react-hook-form\";\nimport { useTranslation } from \"react-i18next\";\nimport { Link, useNavigate } from \"react-router-dom\";\nimport { useAdminClient } from \"../../admin-client\";\nimport { FormAccess } from \"../../components/form/FormAccess\";\nimport { ViewHeader } from \"../../components/view-header/ViewHeader\";\nimport { useParams } from \"../../utils/useParams\";\nimport useToggle from \"../../utils/useToggle\";\nimport { toAuthorizationTab } from \"../routes/AuthenticationTab\";\nimport type { ScopeDetailsParams } from \"../routes/Scope\";\nimport { DeleteScopeDialog } from \"./DeleteScopeDialog\";\n\ntype FormFields = Omit<ScopeRepresentation, \"resources\">;\n\nexport default function ScopeDetails() {\n const { adminClient } = useAdminClient();\n\n const { t } = useTranslation();\n const { id, scopeId, realm } = useParams<ScopeDetailsParams>();\n const navigate = useNavigate();\n const { addAlert, addError } = useAlerts();\n const [deleteDialog, toggleDeleteDialog] = useToggle();\n const [scope, setScope] = useState<ScopeRepresentation>();\n const form = useForm<FormFields>({\n mode: \"onChange\",\n });\n const { reset, handleSubmit } = form;\n\n useFetch(\n async () => {\n if (scopeId) {\n const scope = await adminClient.clients.getAuthorizationScope({\n id,\n scopeId,\n });\n if (!scope) {\n throw new Error(t(\"notFound\"));\n }\n return scope;\n }\n },\n (scope) => {\n setScope(scope);\n reset({ ...scope });\n },\n [],\n );\n\n const onSubmit = async (scope: ScopeRepresentation) => {\n try {\n if (scopeId) {\n await adminClient.clients.updateAuthorizationScope(\n { id, scopeId },\n scope,\n );\n setScope(scope);\n } else {\n await adminClient.clients.createAuthorizationScope(\n { id },\n {\n name: scope.name!,\n displayName: scope.displayName,\n iconUri: scope.iconUri,\n },\n );\n navigate(toAuthorizationTab({ realm, clientId: id, tab: \"scopes\" }));\n }\n addAlert(\n t((scopeId ? \"update\" : \"create\") + \"ScopeSuccess\"),\n AlertVariant.success,\n );\n } catch (error) {\n addError(\"scopeSaveError\", error);\n }\n };\n\n return (\n <>\n <DeleteScopeDialog\n clientId={id}\n open={deleteDialog}\n toggleDialog={toggleDeleteDialog}\n selectedScope={scope}\n refresh={() =>\n navigate(toAuthorizationTab({ realm, clientId: id, tab: \"scopes\" }))\n }\n />\n <ViewHeader\n titleKey={scopeId ? scope?.name! : t(\"createAuthorizationScope\")}\n dropdownItems={\n scopeId\n ? [\n <DropdownItem\n key=\"delete\"\n data-testid=\"delete-resource\"\n onClick={() => toggleDeleteDialog()}\n >\n {t(\"delete\")}\n </DropdownItem>,\n ]\n : undefined\n }\n />\n <PageSection variant=\"light\">\n <FormProvider {...form}>\n <FormAccess\n isHorizontal\n role=\"manage-authorization\"\n onSubmit={handleSubmit(onSubmit)}\n >\n <TextControl\n name=\"name\"\n label={t(\"name\")}\n labelIcon={t(\"scopeNameHelp\")}\n rules={{ required: t(\"required\") }}\n />\n <TextControl\n name=\"displayName\"\n label={t(\"displayName\")}\n labelIcon={t(\"scopeDisplayNameHelp\")}\n />\n <TextControl\n name=\"iconUri\"\n label={t(\"iconUri\")}\n labelIcon={t(\"iconUriHelp\")}\n />\n <ActionGroup>\n <div className=\"pf-v5-u-mt-md\">\n <Button\n variant={ButtonVariant.primary}\n type=\"submit\"\n data-testid=\"save\"\n >\n {t(\"save\")}\n </Button>\n\n {!scope ? (\n <Button\n variant=\"link\"\n data-testid=\"cancel\"\n component={(props) => (\n <Link\n {...props}\n to={toAuthorizationTab({\n realm,\n clientId: id,\n tab: \"scopes\",\n })}\n ></Link>\n )}\n >\n {t(\"cancel\")}\n </Button>\n ) : (\n <Button\n variant=\"link\"\n data-testid=\"revert\"\n onClick={() => reset({ ...scope })}\n >\n {t(\"revert\")}\n </Button>\n )}\n </div>\n </ActionGroup>\n </FormAccess>\n </FormProvider>\n </PageSection>\n </>\n );\n}\n"],"names":["ScopeDetails","adminClient","useAdminClient","t","useTranslation","id","scopeId","realm","useParams","navigate","useNavigate","addAlert","addError","useAlerts","deleteDialog","toggleDeleteDialog","useToggle","scope","setScope","useState","form","useForm","reset","handleSubmit","useFetch","onSubmit","toAuthorizationTab","AlertVariant","error","jsxs","Fragment","jsx","DeleteScopeDialog","ViewHeader","DropdownItem","PageSection","FormProvider","FormAccess","TextControl","ActionGroup","Button","ButtonVariant","props","Link"],"mappings":"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"}
|
@@ -0,0 +1,85 @@
|
|
1
|
+
import { jsx as n, jsxs as F, Fragment as b } from "react/jsx-runtime";
|
2
|
+
import { u as I, ak as P, aU as y, n as O, ar as T, at as j, al as k, am as w, an as z, aw as G, a7 as L, a4 as R } from "./index-CRHbhwXr.js";
|
3
|
+
import { useState as c } from "react";
|
4
|
+
import { useTranslation as H } from "react-i18next";
|
5
|
+
const B = ({
|
6
|
+
clientId: m,
|
7
|
+
resourceTypeScopes: r
|
8
|
+
}) => {
|
9
|
+
const { adminClient: S } = I(), { t: a } = H(), {
|
10
|
+
control: f,
|
11
|
+
formState: { errors: C }
|
12
|
+
} = P(), [x, v] = c(!1), [p, A] = c(), [u, d] = c(""), o = y(m);
|
13
|
+
O(
|
14
|
+
() => {
|
15
|
+
const e = {
|
16
|
+
id: m,
|
17
|
+
first: 0,
|
18
|
+
max: 20,
|
19
|
+
deep: !1,
|
20
|
+
name: u
|
21
|
+
};
|
22
|
+
return S.clients.listAllScopes(e);
|
23
|
+
},
|
24
|
+
A,
|
25
|
+
[u]
|
26
|
+
);
|
27
|
+
const h = (e) => e.map((t, s) => /* @__PURE__ */ n(R, { value: t, children: typeof t == "string" ? t : t.name }, s));
|
28
|
+
if (!p && !r) return /* @__PURE__ */ n(T, {});
|
29
|
+
const g = o && r ? r : p?.map((e) => e.name);
|
30
|
+
return /* @__PURE__ */ n(
|
31
|
+
j,
|
32
|
+
{
|
33
|
+
label: a("authorizationScopes"),
|
34
|
+
labelIcon: /* @__PURE__ */ n(L, { helpText: a("clientScopesHelp"), fieldLabelId: "scopes" }),
|
35
|
+
fieldId: "scopes",
|
36
|
+
isRequired: o,
|
37
|
+
children: /* @__PURE__ */ n(
|
38
|
+
k,
|
39
|
+
{
|
40
|
+
name: "scopes",
|
41
|
+
defaultValue: [],
|
42
|
+
control: f,
|
43
|
+
rules: o ? { required: a("requiredField") } : {},
|
44
|
+
render: ({ field: e }) => {
|
45
|
+
const t = e.value.map((s) => s.name);
|
46
|
+
return /* @__PURE__ */ F(b, { children: [
|
47
|
+
/* @__PURE__ */ n(
|
48
|
+
w,
|
49
|
+
{
|
50
|
+
toggleId: "scopes",
|
51
|
+
variant: z.typeaheadMulti,
|
52
|
+
chipGroupProps: {
|
53
|
+
numChips: 3,
|
54
|
+
expandedText: a("hide"),
|
55
|
+
collapsedText: a("showRemaining")
|
56
|
+
},
|
57
|
+
onToggle: (s) => v(s),
|
58
|
+
isOpen: x,
|
59
|
+
selections: t,
|
60
|
+
onFilter: (s) => (d(s), h(g || [])),
|
61
|
+
onSelect: (s) => {
|
62
|
+
const i = typeof s == "string" ? s : s.name, q = e.value.find(
|
63
|
+
(l) => l.name === i
|
64
|
+
) ? e.value.filter((l) => l.name !== i) : [...e.value, { name: i }];
|
65
|
+
e.onChange(q);
|
66
|
+
},
|
67
|
+
onClear: () => {
|
68
|
+
d(""), e.onChange([]);
|
69
|
+
},
|
70
|
+
typeAheadAriaLabel: a("authorizationScopes"),
|
71
|
+
children: h(g || [])
|
72
|
+
}
|
73
|
+
),
|
74
|
+
o && C.scopes && /* @__PURE__ */ n(G, { message: a("required") })
|
75
|
+
] });
|
76
|
+
}
|
77
|
+
}
|
78
|
+
)
|
79
|
+
}
|
80
|
+
);
|
81
|
+
};
|
82
|
+
export {
|
83
|
+
B as S
|
84
|
+
};
|
85
|
+
//# sourceMappingURL=ScopePicker-kvjSuh0C.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"ScopePicker-kvjSuh0C.js","sources":["../src/clients/authorization/ScopePicker.tsx"],"sourcesContent":["import type ScopeRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/scopeRepresentation\";\nimport {\n FormErrorText,\n HelpItem,\n KeycloakSelect,\n SelectVariant,\n useFetch,\n} from \"@keycloak/keycloak-ui-shared\";\nimport { FormGroup, SelectOption } from \"@patternfly/react-core\";\nimport { useState } from \"react\";\nimport { Controller, useFormContext } from \"react-hook-form\";\nimport { useTranslation } from \"react-i18next\";\nimport { useAdminClient } from \"../../admin-client\";\nimport { KeycloakSpinner } from \"@keycloak/keycloak-ui-shared\";\nimport { useIsAdminPermissionsClient } from \"../../utils/useIsAdminPermissionsClient\";\n\ntype Scope = {\n id: string;\n name: string;\n};\n\ntype ScopePickerProps = {\n clientId: string;\n resourceTypeScopes?: string[];\n};\n\nexport const ScopePicker = ({\n clientId,\n resourceTypeScopes,\n}: ScopePickerProps) => {\n const { adminClient } = useAdminClient();\n const { t } = useTranslation();\n const {\n control,\n formState: { errors },\n } = useFormContext();\n const [open, setOpen] = useState(false);\n const [scopes, setScopes] = useState<ScopeRepresentation[]>();\n const [search, setSearch] = useState(\"\");\n const isAdminPermissionsClient = useIsAdminPermissionsClient(clientId);\n\n useFetch(\n () => {\n const params = {\n id: clientId,\n first: 0,\n max: 20,\n deep: false,\n name: search,\n };\n return adminClient.clients.listAllScopes(params);\n },\n setScopes,\n [search],\n );\n\n const renderScopes = (scopes: ScopeRepresentation[] | string[]) =>\n scopes.map((option, index) => (\n <SelectOption key={index} value={option}>\n {typeof option === \"string\" ? option : option.name}\n </SelectOption>\n ));\n\n if (!scopes && !resourceTypeScopes) return <KeycloakSpinner />;\n\n const allScopes =\n isAdminPermissionsClient && resourceTypeScopes\n ? resourceTypeScopes\n : scopes?.map((scope) => scope.name!);\n\n return (\n <FormGroup\n label={t(\"authorizationScopes\")}\n labelIcon={\n <HelpItem helpText={t(\"clientScopesHelp\")} fieldLabelId=\"scopes\" />\n }\n fieldId=\"scopes\"\n isRequired={isAdminPermissionsClient}\n >\n <Controller\n name=\"scopes\"\n defaultValue={[]}\n control={control}\n rules={isAdminPermissionsClient ? { required: t(\"requiredField\") } : {}}\n render={({ field }) => {\n const selectedValues = field.value.map((o: Scope) => o.name);\n return (\n <>\n <KeycloakSelect\n toggleId=\"scopes\"\n variant={SelectVariant.typeaheadMulti}\n chipGroupProps={{\n numChips: 3,\n expandedText: t(\"hide\"),\n collapsedText: t(\"showRemaining\"),\n }}\n onToggle={(val) => setOpen(val)}\n isOpen={open}\n selections={selectedValues}\n onFilter={(value) => {\n setSearch(value);\n return renderScopes(allScopes || []);\n }}\n onSelect={(selectedValue) => {\n const option =\n typeof selectedValue === \"string\"\n ? selectedValue\n : (selectedValue as Scope).name;\n const changedValue = field.value.find(\n (o: Scope) => o.name === option,\n )\n ? field.value.filter((item: Scope) => item.name !== option)\n : [...field.value, { name: option }];\n field.onChange(changedValue);\n }}\n onClear={() => {\n setSearch(\"\");\n field.onChange([]);\n }}\n typeAheadAriaLabel={t(\"authorizationScopes\")}\n >\n {renderScopes(allScopes || [])}\n </KeycloakSelect>\n {isAdminPermissionsClient && errors.scopes && (\n <FormErrorText message={t(\"required\")} />\n )}\n </>\n );\n }}\n />\n </FormGroup>\n );\n};\n"],"names":["ScopePicker","clientId","resourceTypeScopes","adminClient","useAdminClient","t","useTranslation","control","errors","useFormContext","open","setOpen","useState","scopes","setScopes","search","setSearch","isAdminPermissionsClient","useIsAdminPermissionsClient","useFetch","params","renderScopes","option","index","jsx","SelectOption","KeycloakSpinner","allScopes","scope","FormGroup","HelpItem","Controller","field","selectedValues","o","jsxs","Fragment","KeycloakSelect","SelectVariant","val","value","selectedValue","changedValue","item","FormErrorText"],"mappings":"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"}
|
@@ -0,0 +1,9 @@
|
|
1
|
+
import { AuthenticationProviderRepresentation } from '@keycloak/keycloak-admin-client/lib/defs/authenticatorConfigRepresentation';
|
2
|
+
import { PropsWithChildren } from 'react';
|
3
|
+
export declare const AuthenticationProviderContext: import('libs/ui-shared/dist/utils/createNamedContext').NamedContext<{
|
4
|
+
providers?: AuthenticationProviderRepresentation[];
|
5
|
+
} | undefined>;
|
6
|
+
export declare const AuthenticationProviderContextProvider: ({ children, }: PropsWithChildren) => import("react/jsx-runtime").JSX.Element;
|
7
|
+
export declare const useAuthenticationProvider: () => {
|
8
|
+
providers?: AuthenticationProviderRepresentation[];
|
9
|
+
};
|
@@ -10,5 +10,6 @@ type FlowRowProps = {
|
|
10
10
|
onAddFlow: (execution: ExpandableExecution, flow: Flow) => void;
|
11
11
|
onDelete: (execution: ExpandableExecution) => void;
|
12
12
|
};
|
13
|
+
export type FlowType = "flow" | "condition" | "execution" | "step";
|
13
14
|
export declare const FlowRow: ({ builtIn, execution, onRowClick, onRowChange, onAddExecution, onAddFlow, onDelete, }: FlowRowProps) => import("react/jsx-runtime").JSX.Element;
|
14
15
|
export {};
|
@@ -1,7 +1,10 @@
|
|
1
|
+
import { FlowType } from './FlowRow';
|
1
2
|
type FlowTitleProps = {
|
2
3
|
id?: string;
|
4
|
+
type: FlowType;
|
3
5
|
title: string;
|
4
|
-
|
6
|
+
subtitle: string;
|
7
|
+
providerId?: string;
|
5
8
|
};
|
6
|
-
export declare const FlowTitle: ({ id, title,
|
9
|
+
export declare const FlowTitle: ({ id, type, title, subtitle, providerId, }: FlowTitleProps) => import("react/jsx-runtime").JSX.Element;
|
7
10
|
export {};
|
@@ -1,3 +1,6 @@
|
|
1
|
-
|
1
|
+
type ScopePickerProps = {
|
2
2
|
clientId: string;
|
3
|
-
|
3
|
+
resourceTypeScopes?: string[];
|
4
|
+
};
|
5
|
+
export declare const ScopePicker: ({ clientId, resourceTypeScopes, }: ScopePickerProps) => import("react/jsx-runtime").JSX.Element;
|
6
|
+
export {};
|
@@ -1,5 +1,6 @@
|
|
1
1
|
type NameDescriptionProps = {
|
2
|
-
isDisabled
|
2
|
+
isDisabled?: boolean;
|
3
|
+
clientId?: string;
|
3
4
|
};
|
4
|
-
export declare const NameDescription: ({ isDisabled }: NameDescriptionProps) => import("react/jsx-runtime").JSX.Element;
|
5
|
+
export declare const NameDescription: ({ isDisabled, clientId, }: NameDescriptionProps) => import("react/jsx-runtime").JSX.Element;
|
5
6
|
export {};
|
@@ -0,0 +1,10 @@
|
|
1
|
+
import { Path } from 'react-router-dom';
|
2
|
+
import { AppRouteObject } from '../../routes';
|
3
|
+
export type PermissionConfigurationDetailParams = {
|
4
|
+
realm: string;
|
5
|
+
id: string;
|
6
|
+
permissionId: string;
|
7
|
+
permissionType: string;
|
8
|
+
};
|
9
|
+
export declare const PermissionConfigurationDetailRoute: AppRouteObject;
|
10
|
+
export declare const toPermissionConfigurationDetails: (params: PermissionConfigurationDetailParams) => Partial<Path>;
|
@@ -1,9 +1,11 @@
|
|
1
1
|
import { default as ClientRepresentation } from '@keycloak/keycloak-admin-client/lib/defs/clientRepresentation';
|
2
2
|
import { SelectVariant } from '@keycloak/keycloak-ui-shared';
|
3
3
|
import { ComponentProps } from '../dynamic/components';
|
4
|
-
type ClientSelectProps = ComponentProps & {
|
4
|
+
type ClientSelectProps = Omit<ComponentProps, "convertToName"> & {
|
5
5
|
variant?: `${SelectVariant}`;
|
6
|
+
isRequired?: boolean;
|
6
7
|
clientKey?: keyof ClientRepresentation;
|
8
|
+
placeholderText?: string;
|
7
9
|
};
|
8
|
-
export declare const ClientSelect: ({ name, label, helpText, defaultValue, isDisabled,
|
10
|
+
export declare const ClientSelect: ({ name, label, helpText, defaultValue, isDisabled, isRequired, variant, clientKey, placeholderText, }: ClientSelectProps) => import("react/jsx-runtime").JSX.Element;
|
9
11
|
export {};
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const BooleanComponent: ({ name, label, helpText, isDisabled, defaultValue, isNew, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const BooleanComponent: ({ name, label, helpText, isDisabled, defaultValue, isNew, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -3,7 +3,8 @@ type DynamicComponentProps = {
|
|
3
3
|
properties: ConfigPropertyRepresentation[];
|
4
4
|
stringify?: boolean;
|
5
5
|
isNew?: boolean;
|
6
|
+
convertToName?: (name: string) => string;
|
6
7
|
};
|
7
|
-
export declare const DynamicComponents: ({ properties, ...rest }: DynamicComponentProps) => import("react/jsx-runtime").JSX.Element;
|
8
|
+
export declare const DynamicComponents: ({ convertToName: convert, properties, ...rest }: DynamicComponentProps) => import("react/jsx-runtime").JSX.Element;
|
8
9
|
export declare const convertToName: (name: string) => string;
|
9
10
|
export {};
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const FileComponent: ({ name, label, helpText, defaultValue, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const FileComponent: ({ name, label, helpText, defaultValue, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const GroupComponent: ({ name, label, helpText, required, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const GroupComponent: ({ name, label, helpText, required, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { NumberComponentProps } from './components';
|
2
|
-
export declare const IntComponent: ({ name, label, helpText, ...props }: NumberComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const IntComponent: ({ name, label, helpText, convertToName, ...props }: NumberComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const ListComponent: ({ name, label, helpText, defaultValue, options, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const ListComponent: ({ name, label, helpText, defaultValue, options, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const MapComponent: ({ name, label, helpText, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const MapComponent: ({ name, label, helpText, required, isDisabled, defaultValue, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const MultiValuedListComponent: ({ name, label, helpText, defaultValue, options, isDisabled, stringify, required, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const MultiValuedListComponent: ({ name, label, helpText, defaultValue, options, isDisabled, stringify, required, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const MultiValuedStringComponent: ({ name, label, defaultValue, helpText, stringify, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const MultiValuedStringComponent: ({ name, label, defaultValue, helpText, stringify, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { NumberComponentProps } from './components';
|
2
|
-
export declare const NumberComponent: ({ name, label, helpText, ...props }: NumberComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const NumberComponent: ({ name, label, helpText, convertToName, ...props }: NumberComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const PasswordComponent: ({ name, label, helpText, defaultValue, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const PasswordComponent: ({ name, label, helpText, defaultValue, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const RoleComponent: ({ name, label, helpText, defaultValue, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const RoleComponent: ({ name, label, helpText, defaultValue, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const ScriptComponent: ({ name, label, helpText, defaultValue, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const ScriptComponent: ({ name, label, helpText, defaultValue, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const StringComponent: ({ name, label, helpText, ...props }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const StringComponent: ({ name, label, helpText, convertToName, ...props }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const TextComponent: ({ name, label, helpText, defaultValue, required, isDisabled, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
2
|
+
export declare const TextComponent: ({ name, label, helpText, defaultValue, required, isDisabled, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element;
|
@@ -1,2 +1,2 @@
|
|
1
1
|
import { ComponentProps } from './components';
|
2
|
-
export declare const UserProfileAttributeListComponent: ({ name, label, helpText, required, }: ComponentProps) => import("react/jsx-runtime").JSX.Element | null;
|
2
|
+
export declare const UserProfileAttributeListComponent: ({ name, label, helpText, required, convertToName, }: ComponentProps) => import("react/jsx-runtime").JSX.Element | null;
|
@@ -0,0 +1,12 @@
|
|
1
|
+
type CodeEditorProps = {
|
2
|
+
id?: string;
|
3
|
+
"aria-label"?: string;
|
4
|
+
"data-testid"?: string;
|
5
|
+
value?: string;
|
6
|
+
onChange?: (value: string) => void;
|
7
|
+
language?: string;
|
8
|
+
readOnly?: boolean;
|
9
|
+
height?: number;
|
10
|
+
};
|
11
|
+
declare const CodeEditor: ({ onChange, height, ...rest }: CodeEditorProps) => import("react/jsx-runtime").JSX.Element;
|
12
|
+
export default CodeEditor;
|
@@ -6,7 +6,8 @@ type AddRoleMappingModalProps = {
|
|
6
6
|
isRadio?: boolean;
|
7
7
|
onAssign: (rows: Row[]) => void;
|
8
8
|
onClose: () => void;
|
9
|
-
|
9
|
+
title?: string;
|
10
|
+
actionLabel?: string;
|
10
11
|
};
|
11
|
-
export declare const AddRoleMappingModal: ({ id, name, type, isRadio,
|
12
|
+
export declare const AddRoleMappingModal: ({ id, name, type, isRadio, onAssign, onClose, title, actionLabel, }: AddRoleMappingModalProps) => import("react/jsx-runtime").JSX.Element;
|
12
13
|
export {};
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { ComponentProps } from '../dynamic/components';
|
2
2
|
type UserSelectVariant = "typeaheadMulti" | "typeahead";
|
3
|
-
type UserSelectProps = ComponentProps & {
|
3
|
+
type UserSelectProps = Omit<ComponentProps, "convertToName"> & {
|
4
4
|
variant?: UserSelectVariant;
|
5
5
|
isRequired?: boolean;
|
6
6
|
};
|
@@ -1,4 +1,8 @@
|
|
1
1
|
import { PropsWithChildren } from 'react';
|
2
|
-
export declare const RecentRealmsContext: import('libs/ui-shared/dist/utils/createNamedContext').NamedContext<
|
2
|
+
export declare const RecentRealmsContext: import('libs/ui-shared/dist/utils/createNamedContext').NamedContext<RealmNameRepresentation[] | undefined>;
|
3
|
+
export type RealmNameRepresentation = {
|
4
|
+
name: string;
|
5
|
+
displayName?: string;
|
6
|
+
};
|
3
7
|
export declare const RecentRealmsProvider: ({ children }: PropsWithChildren) => import("react/jsx-runtime").JSX.Element;
|
4
|
-
export declare const useRecentRealms: () =>
|
8
|
+
export declare const useRecentRealms: () => RealmNameRepresentation[];
|