@keycloak/keycloak-admin-ui 26.0.7 → 26.0.8
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/lib/.vite/manifest.json +19 -19
- package/lib/{CreateFlow-uRG_I_sd.js → CreateFlow-D3hVgFZr.js} +13 -13
- package/lib/{CreateFlow-uRG_I_sd.js.map → CreateFlow-D3hVgFZr.js.map} +1 -1
- package/lib/{DetailOrganization-CqbiK2-2.js → DetailOrganization-DUNwCft_.js} +16 -16
- package/lib/{DetailOrganization-CqbiK2-2.js.map → DetailOrganization-DUNwCft_.js.map} +1 -1
- package/lib/{ExecutorForm-CwWVGOtW.js → ExecutorForm-Dp7Iqxos.js} +12 -12
- package/lib/{ExecutorForm-CwWVGOtW.js.map → ExecutorForm-Dp7Iqxos.js.map} +1 -1
- package/lib/{FlowDetails-CRuEMqzE.js → FlowDetails-SHMxH_Rb.js} +438 -438
- package/lib/{FlowDetails-CRuEMqzE.js.map → FlowDetails-SHMxH_Rb.js.map} +1 -1
- package/lib/{NewOrganization-CGV9yUfa.js → NewOrganization-CQAjr9Dn.js} +12 -12
- package/lib/{NewOrganization-CGV9yUfa.js.map → NewOrganization-CQAjr9Dn.js.map} +1 -1
- package/lib/{PermissionDetails-CpjubjMm.js → PermissionDetails-xk5HiPzx.js} +47 -47
- package/lib/{PermissionDetails-CpjubjMm.js.map → PermissionDetails-xk5HiPzx.js.map} +1 -1
- package/lib/{ResourceDetails-BoQE7rAq.js → ResourceDetails-CbJWQn4F.js} +28 -28
- package/lib/{ResourceDetails-BoQE7rAq.js.map → ResourceDetails-CbJWQn4F.js.map} +1 -1
- package/lib/{ScopeDetails-CXbD9GiG.js → ScopeDetails-BtYWOGtn.js} +21 -21
- package/lib/{ScopeDetails-CXbD9GiG.js.map → ScopeDetails-BtYWOGtn.js.map} +1 -1
- package/lib/clients/routes/Client.d.ts +1 -1
- package/lib/context/whoami/WhoAmI.d.ts +1 -0
- package/lib/events/UserEvents.d.ts +6 -0
- package/lib/{index-WPS7MqzE.js → index-6gx7hHms.js} +15073 -15030
- package/lib/index-6gx7hHms.js.map +1 -0
- package/lib/index.d.ts +1 -0
- package/lib/keycloak-admin-ui.js +283 -281
- package/lib/style.css +1 -1
- package/lib/user/routes/User.d.ts +1 -1
- package/package.json +4 -4
- package/lib/index-WPS7MqzE.js.map +0 -1
@@ -1,10 +1,10 @@
|
|
1
|
-
import { jsx as e, jsxs as I, Fragment as
|
2
|
-
import { u as
|
1
|
+
import { jsx as e, jsxs as I, Fragment as T } from "react/jsx-runtime";
|
2
|
+
import { u as N, b5 as q, o as H, bd as L, bf as w, bg as C, b6 as M, b7 as U, b8 as E, aP as G, U as j, b as K, b9 as X, ba as W, aY as Y, bm as $, d as x, bb as D, V as J, aG as Q, P as Z, F as ee, c as ae, X as g, bn as se, bo as re, bp as te, A as ne, B as F, h as oe, aO as le, bq as ie, aN as ce } from "./index-6gx7hHms.js";
|
3
3
|
import { useState as m } from "react";
|
4
4
|
import { useTranslation as V } from "react-i18next";
|
5
5
|
import { useNavigate as ue, Link as de } from "react-router-dom";
|
6
6
|
const me = ({ clientId: l }) => {
|
7
|
-
const { adminClient: a } =
|
7
|
+
const { adminClient: a } = N(), { t: i } = V(), { control: y } = q(), [A, v] = m(!1), [u, S] = m(), [p, b] = m("");
|
8
8
|
H(
|
9
9
|
() => {
|
10
10
|
const o = {
|
@@ -16,15 +16,15 @@ const me = ({ clientId: l }) => {
|
|
16
16
|
};
|
17
17
|
return a.clients.listAllScopes(o);
|
18
18
|
},
|
19
|
-
|
19
|
+
S,
|
20
20
|
[p]
|
21
21
|
);
|
22
|
-
const h = (o) => o.map((s) => /* @__PURE__ */ e(
|
22
|
+
const h = (o) => o.map((s) => /* @__PURE__ */ e(G, { value: s, children: s.name }, s.id));
|
23
23
|
return u ? /* @__PURE__ */ e(
|
24
|
-
|
24
|
+
w,
|
25
25
|
{
|
26
26
|
label: i("authorizationScopes"),
|
27
|
-
labelIcon: /* @__PURE__ */ e(
|
27
|
+
labelIcon: /* @__PURE__ */ e(C, { helpText: i("clientScopesHelp"), fieldLabelId: "scopes" }),
|
28
28
|
fieldId: "scopes",
|
29
29
|
children: /* @__PURE__ */ e(
|
30
30
|
M,
|
@@ -33,10 +33,10 @@ const me = ({ clientId: l }) => {
|
|
33
33
|
defaultValue: [],
|
34
34
|
control: y,
|
35
35
|
render: ({ field: o }) => /* @__PURE__ */ e(
|
36
|
-
|
36
|
+
U,
|
37
37
|
{
|
38
38
|
toggleId: "scopes",
|
39
|
-
variant:
|
39
|
+
variant: E.typeaheadMulti,
|
40
40
|
chipGroupProps: {
|
41
41
|
numChips: 3,
|
42
42
|
expandedText: i("hide"),
|
@@ -65,11 +65,11 @@ const me = ({ clientId: l }) => {
|
|
65
65
|
) : /* @__PURE__ */ e(L, {});
|
66
66
|
};
|
67
67
|
function ve() {
|
68
|
-
const { adminClient: l } =
|
68
|
+
const { adminClient: l } = N(), { t: a } = V(), [i, y] = m(), [A, v] = m(), [u, S] = m(), { addAlert: p, addError: b } = j(), h = K({
|
69
69
|
mode: "onChange"
|
70
|
-
}), { setValue: o, handleSubmit: s } = h, { id: r, resourceId: t, realm: c } =
|
70
|
+
}), { setValue: o, handleSubmit: s } = h, { id: r, resourceId: t, realm: c } = X(), P = ue(), k = (n = {}) => {
|
71
71
|
ce(n, o);
|
72
|
-
}, { hasAccess:
|
72
|
+
}, { hasAccess: O } = W(), R = !O("manage-authorization");
|
73
73
|
H(
|
74
74
|
() => Promise.all([
|
75
75
|
l.clients.findOne({ id: r }),
|
@@ -79,7 +79,7 @@ function ve() {
|
|
79
79
|
([n, d, f]) => {
|
80
80
|
if (!n)
|
81
81
|
throw new Error(a("notFound"));
|
82
|
-
y(n),
|
82
|
+
y(n), S(f), v(d), k(d);
|
83
83
|
},
|
84
84
|
[]
|
85
85
|
);
|
@@ -97,17 +97,17 @@ function ve() {
|
|
97
97
|
}
|
98
98
|
p(
|
99
99
|
a((t ? "update" : "create") + "ResourceSuccess"),
|
100
|
-
|
100
|
+
x.success
|
101
101
|
);
|
102
102
|
} catch (f) {
|
103
103
|
b("resourceSaveError", f);
|
104
104
|
}
|
105
|
-
}, [B, _] =
|
105
|
+
}, [B, _] = Y({
|
106
106
|
titleKey: "deleteResource",
|
107
|
-
children: /* @__PURE__ */ I(
|
107
|
+
children: /* @__PURE__ */ I(T, { children: [
|
108
108
|
a("deleteResourceConfirm"),
|
109
109
|
u?.length !== 0 && /* @__PURE__ */ e(
|
110
|
-
|
110
|
+
$,
|
111
111
|
{
|
112
112
|
variant: "warning",
|
113
113
|
isInline: !0,
|
@@ -124,13 +124,13 @@ function ve() {
|
|
124
124
|
await l.clients.delResource({
|
125
125
|
id: r,
|
126
126
|
resourceId: t
|
127
|
-
}), p(a("resourceDeletedSuccess"),
|
127
|
+
}), p(a("resourceDeletedSuccess"), x.success), P(D({ realm: c, clientId: r, tab: "resources" }));
|
128
128
|
} catch (n) {
|
129
129
|
b("resourceDeletedError", n);
|
130
130
|
}
|
131
131
|
}
|
132
132
|
});
|
133
|
-
return i ? /* @__PURE__ */ I(
|
133
|
+
return i ? /* @__PURE__ */ I(T, { children: [
|
134
134
|
/* @__PURE__ */ e(_, {}),
|
135
135
|
/* @__PURE__ */ e(
|
136
136
|
J,
|
@@ -138,7 +138,7 @@ function ve() {
|
|
138
138
|
titleKey: t ? A?.name : "createResource",
|
139
139
|
dropdownItems: t ? [
|
140
140
|
/* @__PURE__ */ e(
|
141
|
-
|
141
|
+
Q,
|
142
142
|
{
|
143
143
|
"data-testid": "delete-resource",
|
144
144
|
isDisabled: R,
|
@@ -195,11 +195,11 @@ function ve() {
|
|
195
195
|
}
|
196
196
|
),
|
197
197
|
/* @__PURE__ */ e(
|
198
|
-
|
198
|
+
w,
|
199
199
|
{
|
200
200
|
label: a("uris"),
|
201
201
|
fieldId: "uris",
|
202
|
-
labelIcon: /* @__PURE__ */ e(
|
202
|
+
labelIcon: /* @__PURE__ */ e(C, { helpText: a("urisHelp"), fieldLabelId: "uris" }),
|
203
203
|
children: /* @__PURE__ */ e(
|
204
204
|
se,
|
205
205
|
{
|
@@ -230,12 +230,12 @@ function ve() {
|
|
230
230
|
}
|
231
231
|
),
|
232
232
|
/* @__PURE__ */ e(
|
233
|
-
|
233
|
+
w,
|
234
234
|
{
|
235
235
|
hasNoPaddingTop: !0,
|
236
236
|
label: a("resourceAttribute"),
|
237
237
|
labelIcon: /* @__PURE__ */ e(
|
238
|
-
|
238
|
+
C,
|
239
239
|
{
|
240
240
|
helpText: a("resourceAttributeHelp"),
|
241
241
|
fieldLabelId: "resourceAttribute"
|
@@ -247,7 +247,7 @@ function ve() {
|
|
247
247
|
),
|
248
248
|
/* @__PURE__ */ e(ne, { children: /* @__PURE__ */ I("div", { className: "pf-v5-u-mt-md", children: [
|
249
249
|
/* @__PURE__ */ e(
|
250
|
-
|
250
|
+
F,
|
251
251
|
{
|
252
252
|
variant: oe.primary,
|
253
253
|
type: "submit",
|
@@ -256,7 +256,7 @@ function ve() {
|
|
256
256
|
}
|
257
257
|
),
|
258
258
|
/* @__PURE__ */ e(
|
259
|
-
|
259
|
+
F,
|
260
260
|
{
|
261
261
|
variant: "link",
|
262
262
|
"data-testid": "cancel",
|
@@ -264,7 +264,7 @@ function ve() {
|
|
264
264
|
de,
|
265
265
|
{
|
266
266
|
...n,
|
267
|
-
to:
|
267
|
+
to: D({
|
268
268
|
realm: c,
|
269
269
|
clientId: r,
|
270
270
|
tab: "resources"
|
@@ -283,4 +283,4 @@ function ve() {
|
|
283
283
|
export {
|
284
284
|
ve as default
|
285
285
|
};
|
286
|
-
//# sourceMappingURL=ResourceDetails-
|
286
|
+
//# sourceMappingURL=ResourceDetails-CbJWQn4F.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ResourceDetails-BoQE7rAq.js","sources":["../src/clients/authorization/ScopePicker.tsx","../src/clients/authorization/ResourceDetails.tsx"],"sourcesContent":["import type ScopeRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/scopeRepresentation\";\nimport {\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\";\n\ntype Scope = {\n id: string;\n name: string;\n};\n\nexport const ScopePicker = ({ clientId }: { clientId: string }) => {\n const { adminClient } = useAdminClient();\n\n const { t } = useTranslation();\n const { control } = useFormContext();\n\n const [open, setOpen] = useState(false);\n const [scopes, setScopes] = useState<ScopeRepresentation[]>();\n const [search, setSearch] = useState(\"\");\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[]) =>\n scopes.map((option) => (\n <SelectOption key={option.id} value={option}>\n {option.name}\n </SelectOption>\n ));\n\n if (!scopes) return <KeycloakSpinner />;\n return (\n <FormGroup\n label={t(\"authorizationScopes\")}\n labelIcon={\n <HelpItem helpText={t(\"clientScopesHelp\")} fieldLabelId=\"scopes\" />\n }\n fieldId=\"scopes\"\n >\n <Controller\n name=\"scopes\"\n defaultValue={[]}\n control={control}\n render={({ field }) => (\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={field.value.map((o: Scope) => o.name)}\n onFilter={(value) => {\n setSearch(value);\n return renderScopes(scopes);\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, selectedValue];\n field.onChange(changedValue);\n }}\n onClear={() => {\n setSearch(\"\");\n field.onChange([]);\n }}\n typeAheadAriaLabel={t(\"authorizationScopes\")}\n >\n {renderScopes(scopes)}\n </KeycloakSelect>\n )}\n />\n </FormGroup>\n );\n};\n","import type ClientRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/clientRepresentation\";\nimport type ResourceRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/resourceRepresentation\";\nimport type ResourceServerRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/resourceServerRepresentation\";\nimport {\n HelpItem,\n TextControl,\n useAlerts,\n useFetch,\n} from \"@keycloak/keycloak-ui-shared\";\nimport {\n ActionGroup,\n Alert,\n AlertVariant,\n Button,\n ButtonVariant,\n DropdownItem,\n FormGroup,\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 { DefaultSwitchControl } from \"../../components/SwitchControl\";\nimport { useConfirmDialog } from \"../../components/confirm-dialog/ConfirmDialog\";\nimport { FormAccess } from \"../../components/form/FormAccess\";\nimport { KeyValueInput } from \"../../components/key-value-form/KeyValueInput\";\nimport type { KeyValueType } from \"../../components/key-value-form/key-value-convert\";\nimport { KeycloakSpinner } from \"@keycloak/keycloak-ui-shared\";\nimport { MultiLineInput } from \"../../components/multi-line-input/MultiLineInput\";\nimport { ViewHeader } from \"../../components/view-header/ViewHeader\";\nimport { useAccess } from \"../../context/access/Access\";\nimport { convertFormValuesToObject, convertToFormValues } from \"../../util\";\nimport { useParams } from \"../../utils/useParams\";\nimport { toAuthorizationTab } from \"../routes/AuthenticationTab\";\nimport { ResourceDetailsParams, toResourceDetails } from \"../routes/Resource\";\nimport { ScopePicker } from \"./ScopePicker\";\nimport \"./resource-details.css\";\n\ntype SubmittedResource = Omit<\n ResourceRepresentation,\n \"attributes\" | \"scopes\"\n> & {\n attributes: KeyValueType[];\n};\n\nexport default function ResourceDetails() {\n const { adminClient } = useAdminClient();\n\n const { t } = useTranslation();\n const [client, setClient] = useState<ClientRepresentation>();\n const [resource, setResource] = useState<ResourceRepresentation>();\n\n const [permissions, setPermission] =\n useState<ResourceServerRepresentation[]>();\n\n const { addAlert, addError } = useAlerts();\n const form = useForm<SubmittedResource>({\n mode: \"onChange\",\n });\n const { setValue, handleSubmit } = form;\n\n const { id, resourceId, realm } = useParams<ResourceDetailsParams>();\n const navigate = useNavigate();\n\n const setupForm = (resource: ResourceRepresentation = {}) => {\n convertToFormValues(resource, setValue);\n };\n\n const { hasAccess } = useAccess();\n\n const isDisabled = !hasAccess(\"manage-authorization\");\n\n useFetch(\n () =>\n Promise.all([\n adminClient.clients.findOne({ id }),\n resourceId\n ? adminClient.clients.getResource({ id, resourceId })\n : Promise.resolve(undefined),\n resourceId\n ? adminClient.clients.listPermissionsByResource({ id, resourceId })\n : Promise.resolve(undefined),\n ]),\n ([client, resource, permissions]) => {\n if (!client) {\n throw new Error(t(\"notFound\"));\n }\n setClient(client);\n setPermission(permissions);\n setResource(resource);\n setupForm(resource);\n },\n [],\n );\n\n const submit = async (submitted: SubmittedResource) => {\n const resource = convertFormValuesToObject<\n SubmittedResource,\n ResourceRepresentation\n >(submitted);\n\n try {\n if (resourceId) {\n await adminClient.clients.updateResource({ id, resourceId }, resource);\n } else {\n const result = await adminClient.clients.createResource(\n { id },\n resource,\n );\n setResource(resource);\n navigate(toResourceDetails({ realm, id, resourceId: result._id! }));\n }\n addAlert(\n t((resourceId ? \"update\" : \"create\") + \"ResourceSuccess\"),\n AlertVariant.success,\n );\n } catch (error) {\n addError(\"resourceSaveError\", error);\n }\n };\n\n const [toggleDeleteDialog, DeleteConfirm] = useConfirmDialog({\n titleKey: \"deleteResource\",\n children: (\n <>\n {t(\"deleteResourceConfirm\")}\n {permissions?.length !== 0 && (\n <Alert\n variant=\"warning\"\n isInline\n isPlain\n title={t(\"deleteResourceWarning\")}\n className=\"pf-v5-u-pt-lg\"\n >\n <p className=\"pf-v5-u-pt-xs\">\n {permissions?.map((permission) => (\n <strong key={permission.id} className=\"pf-v5-u-pr-md\">\n {permission.name}\n </strong>\n ))}\n </p>\n </Alert>\n )}\n </>\n ),\n continueButtonLabel: \"confirm\",\n onConfirm: async () => {\n try {\n await adminClient.clients.delResource({\n id,\n resourceId: resourceId!,\n });\n addAlert(t(\"resourceDeletedSuccess\"), AlertVariant.success);\n navigate(toAuthorizationTab({ realm, clientId: id, tab: \"resources\" }));\n } catch (error) {\n addError(\"resourceDeletedError\", error);\n }\n },\n });\n\n if (!client) {\n return <KeycloakSpinner />;\n }\n\n return (\n <>\n <DeleteConfirm />\n <ViewHeader\n titleKey={resourceId ? resource?.name! : \"createResource\"}\n dropdownItems={\n resourceId\n ? [\n <DropdownItem\n key=\"delete\"\n data-testid=\"delete-resource\"\n isDisabled={isDisabled}\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 className=\"keycloak__resource-details__form\"\n onSubmit={handleSubmit(submit)}\n >\n <TextControl\n name={resourceId ? \"owner.name\" : \"\"}\n label={t(\"owner\")}\n labelIcon={t(\"ownerHelp\")}\n defaultValue={client.clientId}\n readOnly\n />\n <TextControl\n name={\"name\"}\n label={t(\"name\")}\n labelIcon={t(\"resourceNameHelp\")}\n rules={{ required: t(\"required\") }}\n />\n <TextControl\n name=\"displayName\"\n label={t(\"displayName\")}\n labelIcon={t(\"displayNameHelp\")}\n rules={{ required: t(\"required\") }}\n />\n <TextControl\n name=\"type\"\n label={t(\"type\")}\n labelIcon={t(\"resourceDetailsTypeHelp\")}\n />\n <FormGroup\n label={t(\"uris\")}\n fieldId=\"uris\"\n labelIcon={\n <HelpItem helpText={t(\"urisHelp\")} fieldLabelId=\"uris\" />\n }\n >\n <MultiLineInput\n name=\"uris\"\n type=\"url\"\n aria-label={t(\"uris\")}\n addButtonLabel=\"addUri\"\n />\n </FormGroup>\n <ScopePicker clientId={id} />\n <TextControl\n name=\"icon_uri\"\n label={t(\"iconUri\")}\n labelIcon={t(\"iconUriHelp\")}\n type=\"url\"\n />\n <DefaultSwitchControl\n name=\"ownerManagedAccess\"\n label={t(\"ownerManagedAccess\")}\n labelIcon={t(\"ownerManagedAccessHelp\")}\n />\n <FormGroup\n hasNoPaddingTop\n label={t(\"resourceAttribute\")}\n labelIcon={\n <HelpItem\n helpText={t(\"resourceAttributeHelp\")}\n fieldLabelId=\"resourceAttribute\"\n />\n }\n fieldId=\"resourceAttribute\"\n >\n <KeyValueInput name=\"attributes\" isDisabled={isDisabled} />\n </FormGroup>\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 <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: \"resources\",\n })}\n ></Link>\n )}\n >\n {t(\"cancel\")}\n </Button>\n </div>\n </ActionGroup>\n </FormAccess>\n </FormProvider>\n </PageSection>\n </>\n );\n}\n"],"names":["ScopePicker","clientId","adminClient","useAdminClient","t","useTranslation","control","useFormContext","open","setOpen","useState","scopes","setScopes","search","setSearch","useFetch","params","renderScopes","option","jsx","SelectOption","FormGroup","HelpItem","Controller","field","KeycloakSelect","SelectVariant","val","o","value","selectedValue","changedValue","item","KeycloakSpinner","ResourceDetails","client","setClient","resource","setResource","permissions","setPermission","addAlert","addError","useAlerts","form","useForm","setValue","handleSubmit","id","resourceId","realm","useParams","navigate","useNavigate","setupForm","convertToFormValues","hasAccess","useAccess","isDisabled","submit","submitted","convertFormValuesToObject","result","toResourceDetails","AlertVariant","error","toggleDeleteDialog","DeleteConfirm","useConfirmDialog","jsxs","Fragment","Alert","permission","toAuthorizationTab","ViewHeader","DropdownItem","PageSection","FormProvider","FormAccess","TextControl","MultiLineInput","DefaultSwitchControl","KeyValueInput","ActionGroup","Button","ButtonVariant","props","Link"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"ResourceDetails-CbJWQn4F.js","sources":["../src/clients/authorization/ScopePicker.tsx","../src/clients/authorization/ResourceDetails.tsx"],"sourcesContent":["import type ScopeRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/scopeRepresentation\";\nimport {\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\";\n\ntype Scope = {\n id: string;\n name: string;\n};\n\nexport const ScopePicker = ({ clientId }: { clientId: string }) => {\n const { adminClient } = useAdminClient();\n\n const { t } = useTranslation();\n const { control } = useFormContext();\n\n const [open, setOpen] = useState(false);\n const [scopes, setScopes] = useState<ScopeRepresentation[]>();\n const [search, setSearch] = useState(\"\");\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[]) =>\n scopes.map((option) => (\n <SelectOption key={option.id} value={option}>\n {option.name}\n </SelectOption>\n ));\n\n if (!scopes) return <KeycloakSpinner />;\n return (\n <FormGroup\n label={t(\"authorizationScopes\")}\n labelIcon={\n <HelpItem helpText={t(\"clientScopesHelp\")} fieldLabelId=\"scopes\" />\n }\n fieldId=\"scopes\"\n >\n <Controller\n name=\"scopes\"\n defaultValue={[]}\n control={control}\n render={({ field }) => (\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={field.value.map((o: Scope) => o.name)}\n onFilter={(value) => {\n setSearch(value);\n return renderScopes(scopes);\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, selectedValue];\n field.onChange(changedValue);\n }}\n onClear={() => {\n setSearch(\"\");\n field.onChange([]);\n }}\n typeAheadAriaLabel={t(\"authorizationScopes\")}\n >\n {renderScopes(scopes)}\n </KeycloakSelect>\n )}\n />\n </FormGroup>\n );\n};\n","import type ClientRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/clientRepresentation\";\nimport type ResourceRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/resourceRepresentation\";\nimport type ResourceServerRepresentation from \"@keycloak/keycloak-admin-client/lib/defs/resourceServerRepresentation\";\nimport {\n HelpItem,\n TextControl,\n useAlerts,\n useFetch,\n} from \"@keycloak/keycloak-ui-shared\";\nimport {\n ActionGroup,\n Alert,\n AlertVariant,\n Button,\n ButtonVariant,\n DropdownItem,\n FormGroup,\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 { DefaultSwitchControl } from \"../../components/SwitchControl\";\nimport { useConfirmDialog } from \"../../components/confirm-dialog/ConfirmDialog\";\nimport { FormAccess } from \"../../components/form/FormAccess\";\nimport { KeyValueInput } from \"../../components/key-value-form/KeyValueInput\";\nimport type { KeyValueType } from \"../../components/key-value-form/key-value-convert\";\nimport { KeycloakSpinner } from \"@keycloak/keycloak-ui-shared\";\nimport { MultiLineInput } from \"../../components/multi-line-input/MultiLineInput\";\nimport { ViewHeader } from \"../../components/view-header/ViewHeader\";\nimport { useAccess } from \"../../context/access/Access\";\nimport { convertFormValuesToObject, convertToFormValues } from \"../../util\";\nimport { useParams } from \"../../utils/useParams\";\nimport { toAuthorizationTab } from \"../routes/AuthenticationTab\";\nimport { ResourceDetailsParams, toResourceDetails } from \"../routes/Resource\";\nimport { ScopePicker } from \"./ScopePicker\";\nimport \"./resource-details.css\";\n\ntype SubmittedResource = Omit<\n ResourceRepresentation,\n \"attributes\" | \"scopes\"\n> & {\n attributes: KeyValueType[];\n};\n\nexport default function ResourceDetails() {\n const { adminClient } = useAdminClient();\n\n const { t } = useTranslation();\n const [client, setClient] = useState<ClientRepresentation>();\n const [resource, setResource] = useState<ResourceRepresentation>();\n\n const [permissions, setPermission] =\n useState<ResourceServerRepresentation[]>();\n\n const { addAlert, addError } = useAlerts();\n const form = useForm<SubmittedResource>({\n mode: \"onChange\",\n });\n const { setValue, handleSubmit } = form;\n\n const { id, resourceId, realm } = useParams<ResourceDetailsParams>();\n const navigate = useNavigate();\n\n const setupForm = (resource: ResourceRepresentation = {}) => {\n convertToFormValues(resource, setValue);\n };\n\n const { hasAccess } = useAccess();\n\n const isDisabled = !hasAccess(\"manage-authorization\");\n\n useFetch(\n () =>\n Promise.all([\n adminClient.clients.findOne({ id }),\n resourceId\n ? adminClient.clients.getResource({ id, resourceId })\n : Promise.resolve(undefined),\n resourceId\n ? adminClient.clients.listPermissionsByResource({ id, resourceId })\n : Promise.resolve(undefined),\n ]),\n ([client, resource, permissions]) => {\n if (!client) {\n throw new Error(t(\"notFound\"));\n }\n setClient(client);\n setPermission(permissions);\n setResource(resource);\n setupForm(resource);\n },\n [],\n );\n\n const submit = async (submitted: SubmittedResource) => {\n const resource = convertFormValuesToObject<\n SubmittedResource,\n ResourceRepresentation\n >(submitted);\n\n try {\n if (resourceId) {\n await adminClient.clients.updateResource({ id, resourceId }, resource);\n } else {\n const result = await adminClient.clients.createResource(\n { id },\n resource,\n );\n setResource(resource);\n navigate(toResourceDetails({ realm, id, resourceId: result._id! }));\n }\n addAlert(\n t((resourceId ? \"update\" : \"create\") + \"ResourceSuccess\"),\n AlertVariant.success,\n );\n } catch (error) {\n addError(\"resourceSaveError\", error);\n }\n };\n\n const [toggleDeleteDialog, DeleteConfirm] = useConfirmDialog({\n titleKey: \"deleteResource\",\n children: (\n <>\n {t(\"deleteResourceConfirm\")}\n {permissions?.length !== 0 && (\n <Alert\n variant=\"warning\"\n isInline\n isPlain\n title={t(\"deleteResourceWarning\")}\n className=\"pf-v5-u-pt-lg\"\n >\n <p className=\"pf-v5-u-pt-xs\">\n {permissions?.map((permission) => (\n <strong key={permission.id} className=\"pf-v5-u-pr-md\">\n {permission.name}\n </strong>\n ))}\n </p>\n </Alert>\n )}\n </>\n ),\n continueButtonLabel: \"confirm\",\n onConfirm: async () => {\n try {\n await adminClient.clients.delResource({\n id,\n resourceId: resourceId!,\n });\n addAlert(t(\"resourceDeletedSuccess\"), AlertVariant.success);\n navigate(toAuthorizationTab({ realm, clientId: id, tab: \"resources\" }));\n } catch (error) {\n addError(\"resourceDeletedError\", error);\n }\n },\n });\n\n if (!client) {\n return <KeycloakSpinner />;\n }\n\n return (\n <>\n <DeleteConfirm />\n <ViewHeader\n titleKey={resourceId ? resource?.name! : \"createResource\"}\n dropdownItems={\n resourceId\n ? [\n <DropdownItem\n key=\"delete\"\n data-testid=\"delete-resource\"\n isDisabled={isDisabled}\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 className=\"keycloak__resource-details__form\"\n onSubmit={handleSubmit(submit)}\n >\n <TextControl\n name={resourceId ? \"owner.name\" : \"\"}\n label={t(\"owner\")}\n labelIcon={t(\"ownerHelp\")}\n defaultValue={client.clientId}\n readOnly\n />\n <TextControl\n name={\"name\"}\n label={t(\"name\")}\n labelIcon={t(\"resourceNameHelp\")}\n rules={{ required: t(\"required\") }}\n />\n <TextControl\n name=\"displayName\"\n label={t(\"displayName\")}\n labelIcon={t(\"displayNameHelp\")}\n rules={{ required: t(\"required\") }}\n />\n <TextControl\n name=\"type\"\n label={t(\"type\")}\n labelIcon={t(\"resourceDetailsTypeHelp\")}\n />\n <FormGroup\n label={t(\"uris\")}\n fieldId=\"uris\"\n labelIcon={\n <HelpItem helpText={t(\"urisHelp\")} fieldLabelId=\"uris\" />\n }\n >\n <MultiLineInput\n name=\"uris\"\n type=\"url\"\n aria-label={t(\"uris\")}\n addButtonLabel=\"addUri\"\n />\n </FormGroup>\n <ScopePicker clientId={id} />\n <TextControl\n name=\"icon_uri\"\n label={t(\"iconUri\")}\n labelIcon={t(\"iconUriHelp\")}\n type=\"url\"\n />\n <DefaultSwitchControl\n name=\"ownerManagedAccess\"\n label={t(\"ownerManagedAccess\")}\n labelIcon={t(\"ownerManagedAccessHelp\")}\n />\n <FormGroup\n hasNoPaddingTop\n label={t(\"resourceAttribute\")}\n labelIcon={\n <HelpItem\n helpText={t(\"resourceAttributeHelp\")}\n fieldLabelId=\"resourceAttribute\"\n />\n }\n fieldId=\"resourceAttribute\"\n >\n <KeyValueInput name=\"attributes\" isDisabled={isDisabled} />\n </FormGroup>\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 <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: \"resources\",\n })}\n ></Link>\n )}\n >\n {t(\"cancel\")}\n </Button>\n </div>\n </ActionGroup>\n </FormAccess>\n </FormProvider>\n </PageSection>\n </>\n );\n}\n"],"names":["ScopePicker","clientId","adminClient","useAdminClient","t","useTranslation","control","useFormContext","open","setOpen","useState","scopes","setScopes","search","setSearch","useFetch","params","renderScopes","option","jsx","SelectOption","FormGroup","HelpItem","Controller","field","KeycloakSelect","SelectVariant","val","o","value","selectedValue","changedValue","item","KeycloakSpinner","ResourceDetails","client","setClient","resource","setResource","permissions","setPermission","addAlert","addError","useAlerts","form","useForm","setValue","handleSubmit","id","resourceId","realm","useParams","navigate","useNavigate","setupForm","convertToFormValues","hasAccess","useAccess","isDisabled","submit","submitted","convertFormValuesToObject","result","toResourceDetails","AlertVariant","error","toggleDeleteDialog","DeleteConfirm","useConfirmDialog","jsxs","Fragment","Alert","permission","toAuthorizationTab","ViewHeader","DropdownItem","PageSection","FormProvider","FormAccess","TextControl","MultiLineInput","DefaultSwitchControl","KeyValueInput","ActionGroup","Button","ButtonVariant","props","Link"],"mappings":"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"}
|
@@ -1,18 +1,18 @@
|
|
1
1
|
import { jsxs as c, Fragment as D, jsx as t } from "react/jsx-runtime";
|
2
|
-
import { u as w, b9 as N,
|
2
|
+
import { u as w, b9 as N, U as z, aH as U, b as k, o as F, br as H, bb as l, V as C, aG as P, P as V, F as x, c as B, X as d, A as E, B as m, h as T, d as j } from "./index-6gx7hHms.js";
|
3
3
|
import { useState as q } from "react";
|
4
4
|
import { useTranslation as G } from "react-i18next";
|
5
|
-
import { useNavigate as
|
5
|
+
import { useNavigate as X, Link as K } from "react-router-dom";
|
6
6
|
function R() {
|
7
|
-
const { adminClient: r } = w(), { t: e } = G(), { id:
|
7
|
+
const { adminClient: r } = w(), { t: e } = G(), { id: o, scopeId: i, realm: s } = N(), p = X(), { addAlert: S, addError: v } = z(), [f, u] = U(), [n, h] = q(), b = k({
|
8
8
|
mode: "onChange"
|
9
9
|
}), { reset: g, handleSubmit: y } = b;
|
10
|
-
|
10
|
+
F(
|
11
11
|
async () => {
|
12
|
-
if (
|
12
|
+
if (i) {
|
13
13
|
const a = await r.clients.getAuthorizationScope({
|
14
|
-
id:
|
15
|
-
scopeId:
|
14
|
+
id: o,
|
15
|
+
scopeId: i
|
16
16
|
});
|
17
17
|
if (!a)
|
18
18
|
throw new Error(e("notFound"));
|
@@ -26,18 +26,18 @@ function R() {
|
|
26
26
|
);
|
27
27
|
const A = async (a) => {
|
28
28
|
try {
|
29
|
-
|
30
|
-
{ id:
|
29
|
+
i ? (await r.clients.updateAuthorizationScope(
|
30
|
+
{ id: o, scopeId: i },
|
31
31
|
a
|
32
32
|
), h(a)) : (await r.clients.createAuthorizationScope(
|
33
|
-
{ id:
|
33
|
+
{ id: o },
|
34
34
|
{
|
35
35
|
name: a.name,
|
36
36
|
displayName: a.displayName,
|
37
37
|
iconUri: a.iconUri
|
38
38
|
}
|
39
|
-
), p(l({ realm: s, clientId:
|
40
|
-
e((
|
39
|
+
), p(l({ realm: s, clientId: o, tab: "scopes" }))), S(
|
40
|
+
e((i ? "update" : "create") + "ScopeSuccess"),
|
41
41
|
j.success
|
42
42
|
);
|
43
43
|
} catch (I) {
|
@@ -46,20 +46,20 @@ function R() {
|
|
46
46
|
};
|
47
47
|
return /* @__PURE__ */ c(D, { children: [
|
48
48
|
/* @__PURE__ */ t(
|
49
|
-
|
49
|
+
H,
|
50
50
|
{
|
51
|
-
clientId:
|
51
|
+
clientId: o,
|
52
52
|
open: f,
|
53
53
|
toggleDialog: u,
|
54
54
|
selectedScope: n,
|
55
|
-
refresh: () => p(l({ realm: s, clientId:
|
55
|
+
refresh: () => p(l({ realm: s, clientId: o, tab: "scopes" }))
|
56
56
|
}
|
57
57
|
),
|
58
58
|
/* @__PURE__ */ t(
|
59
|
-
|
59
|
+
C,
|
60
60
|
{
|
61
|
-
titleKey:
|
62
|
-
dropdownItems:
|
61
|
+
titleKey: i ? n?.name : e("createAuthorizationScope"),
|
62
|
+
dropdownItems: i ? [
|
63
63
|
/* @__PURE__ */ t(
|
64
64
|
P,
|
65
65
|
{
|
@@ -128,12 +128,12 @@ function R() {
|
|
128
128
|
variant: "link",
|
129
129
|
"data-testid": "cancel",
|
130
130
|
component: (a) => /* @__PURE__ */ t(
|
131
|
-
|
131
|
+
K,
|
132
132
|
{
|
133
133
|
...a,
|
134
134
|
to: l({
|
135
135
|
realm: s,
|
136
|
-
clientId:
|
136
|
+
clientId: o,
|
137
137
|
tab: "scopes"
|
138
138
|
})
|
139
139
|
}
|
@@ -150,4 +150,4 @@ function R() {
|
|
150
150
|
export {
|
151
151
|
R as default
|
152
152
|
};
|
153
|
-
//# sourceMappingURL=ScopeDetails-
|
153
|
+
//# sourceMappingURL=ScopeDetails-BtYWOGtn.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ScopeDetails-
|
1
|
+
{"version":3,"file":"ScopeDetails-BtYWOGtn.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":";;;;;AAyBA,SAAwBA,IAAe;AAC/B,QAAA,EAAE,aAAAC,MAAgBC,KAElB,EAAE,GAAAC,MAAMC,KACR,EAAE,IAAAC,GAAI,SAAAC,GAAS,OAAAC,MAAUC,EAA8B,GACvDC,IAAWC,KACX,EAAE,UAAAC,GAAU,UAAAC,EAAS,IAAIC,EAAU,GACnC,CAACC,GAAcC,CAAkB,IAAIC,EAAU,GAC/C,CAACC,GAAOC,CAAQ,IAAIC,EAA8B,GAClDC,IAAOC,EAAoB;AAAA,IAC/B,MAAM;AAAA,EAAA,CACP,GACK,EAAE,OAAAC,GAAO,cAAAC,EAAiB,IAAAH;AAEhCI,EAAAA;AAAAA,IACE,YAAY;AACV,UAAIlB,GAAS;AACX,cAAMW,IAAQ,MAAMhB,EAAY,QAAQ,sBAAsB;AAAA,UAC5D,IAAAI;AAAA,UACA,SAAAC;AAAA,QAAA,CACD;AACD,YAAI,CAACW;AACH,gBAAM,IAAI,MAAMd,EAAE,UAAU,CAAC;AAExBc,eAAAA;AAAAA,MACT;AAAA,IACF;AAAA,IACA,CAACA,MAAU;AACT,MAAAC,EAASD,CAAK,GACRK,EAAA,EAAE,GAAGL,EAAAA,CAAO;AAAA,IACpB;AAAA,IACA,CAAC;AAAA,EAAA;AAGG,QAAAQ,IAAW,OAAOR,MAA+B;AACjD,QAAA;AACF,MAAIX,KACF,MAAML,EAAY,QAAQ;AAAA,QACxB,EAAE,IAAAI,GAAI,SAAAC,EAAQ;AAAA,QACdW;AAAAA,MAAA,GAEFC,EAASD,CAAK,MAEd,MAAMhB,EAAY,QAAQ;AAAA,QACxB,EAAE,IAAAI,EAAG;AAAA,QACL;AAAA,UACE,MAAMY,EAAM;AAAA,UACZ,aAAaA,EAAM;AAAA,UACnB,SAASA,EAAM;AAAA,QACjB;AAAA,MAAA,GAEOR,EAAAiB,EAAmB,EAAE,OAAAnB,GAAO,UAAUF,GAAI,KAAK,SAAU,CAAA,CAAC,IAErEM;AAAA,QACER,GAAGG,IAAU,WAAW,YAAY,cAAc;AAAA,QAClDqB,EAAa;AAAA,MAAA;AAAA,aAERC,GAAO;AACd,MAAAhB,EAAS,kBAAkBgB,CAAK;AAAA,IAClC;AAAA,EAAA;AAGF,SAEI,gBAAAC,EAAAC,GAAA,EAAA,UAAA;AAAA,IAAA,gBAAAC;AAAA,MAACC;AAAA,MAAA;AAAA,QACC,UAAU3B;AAAA,QACV,MAAMS;AAAA,QACN,cAAcC;AAAA,QACd,eAAeE;AAAA,QACf,SAAS,MACPR,EAASiB,EAAmB,EAAE,OAAAnB,GAAO,UAAUF,GAAI,KAAK,SAAS,CAAC,CAAC;AAAA,MAAA;AAAA,IAEvE;AAAA,IACA,gBAAA0B;AAAA,MAACE;AAAA,MAAA;AAAA,QACC,UAAU3B,IAAUW,GAAO,OAAQd,EAAE,0BAA0B;AAAA,QAC/D,eACEG,IACI;AAAA,UACE,gBAAAyB;AAAA,YAACG;AAAA,YAAA;AAAA,cAEC,eAAY;AAAA,cACZ,SAAS,MAAMnB,EAAmB;AAAA,cAEjC,YAAE,QAAQ;AAAA,YAAA;AAAA,YAJP;AAAA,UAKN;AAAA,QAEF,IAAA;AAAA,MAAA;AAAA,IAER;AAAA,sBACCoB,GAAY,EAAA,SAAQ,SACnB,UAAC,gBAAAJ,EAAAK,GAAA,EAAc,GAAGhB,GAChB,UAAA,gBAAAS;AAAA,MAACQ;AAAA,MAAA;AAAA,QACC,cAAY;AAAA,QACZ,MAAK;AAAA,QACL,UAAUd,EAAaE,CAAQ;AAAA,QAE/B,UAAA;AAAA,UAAA,gBAAAM;AAAA,YAACO;AAAAA,YAAA;AAAA,cACC,MAAK;AAAA,cACL,OAAOnC,EAAE,MAAM;AAAA,cACf,WAAWA,EAAE,eAAe;AAAA,cAC5B,OAAO,EAAE,UAAUA,EAAE,UAAU,EAAE;AAAA,YAAA;AAAA,UACnC;AAAA,UACA,gBAAA4B;AAAA,YAACO;AAAAA,YAAA;AAAA,cACC,MAAK;AAAA,cACL,OAAOnC,EAAE,aAAa;AAAA,cACtB,WAAWA,EAAE,sBAAsB;AAAA,YAAA;AAAA,UACrC;AAAA,UACA,gBAAA4B;AAAA,YAACO;AAAAA,YAAA;AAAA,cACC,MAAK;AAAA,cACL,OAAOnC,EAAE,SAAS;AAAA,cAClB,WAAWA,EAAE,aAAa;AAAA,YAAA;AAAA,UAC5B;AAAA,UACC,gBAAA4B,EAAAQ,GAAA,EACC,UAAC,gBAAAV,EAAA,OAAA,EAAI,WAAU,iBACb,UAAA;AAAA,YAAA,gBAAAE;AAAA,cAACS;AAAA,cAAA;AAAA,gBACC,SAASC,EAAc;AAAA,gBACvB,MAAK;AAAA,gBACL,eAAY;AAAA,gBAEX,YAAE,MAAM;AAAA,cAAA;AAAA,YACX;AAAA,YAEExB,IAkBA,gBAAAc;AAAA,cAACS;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,eAAY;AAAA,gBACZ,SAAS,MAAMlB,EAAM,EAAE,GAAGL,GAAO;AAAA,gBAEhC,YAAE,QAAQ;AAAA,cAAA;AAAA,YACb,IAvBA,gBAAAc;AAAA,cAACS;AAAA,cAAA;AAAA,gBACC,SAAQ;AAAA,gBACR,eAAY;AAAA,gBACZ,WAAW,CAACE,MACV,gBAAAX;AAAA,kBAACY;AAAA,kBAAA;AAAA,oBACE,GAAGD;AAAA,oBACJ,IAAIhB,EAAmB;AAAA,sBACrB,OAAAnB;AAAA,sBACA,UAAUF;AAAA,sBACV,KAAK;AAAA,oBAAA,CACN;AAAA,kBAAA;AAAA,gBACF;AAAA,gBAGF,YAAE,QAAQ;AAAA,cAAA;AAAA,YAAA;AAAA,UASb,EAAA,CAEJ,EACF,CAAA;AAAA,QAAA;AAAA,MAAA;AAAA,OAEJ,EACF,CAAA;AAAA,EACF,EAAA,CAAA;AAEJ;"}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Path } from 'react-router-dom';
|
2
2
|
import { AppRouteObject } from '../../routes';
|
3
|
-
export type ClientTab = "settings" | "keys" | "credentials" | "roles" | "clientScopes" | "advanced" | "mappers" | "authorization" | "serviceAccount" | "permissions" | "sessions";
|
3
|
+
export type ClientTab = "settings" | "keys" | "credentials" | "roles" | "clientScopes" | "advanced" | "mappers" | "authorization" | "serviceAccount" | "permissions" | "sessions" | "user-events";
|
4
4
|
export type ClientParams = {
|
5
5
|
realm: string;
|
6
6
|
clientId: string;
|