@keycloak/keycloak-admin-ui 26.0.8 → 26.1.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/lib/.vite/manifest.json +30 -21
- package/lib/App.d.ts +2 -0
- package/lib/Banners.d.ts +5 -0
- package/lib/{CreateFlow-D3hVgFZr.js → CreateFlow-BP640UYh.js} +9 -9
- package/lib/{CreateFlow-D3hVgFZr.js.map → CreateFlow-BP640UYh.js.map} +1 -1
- package/lib/DetailOrganization-DmvcJpiT.js +164 -0
- package/lib/DetailOrganization-DmvcJpiT.js.map +1 -0
- package/lib/{ExecutorForm-Dp7Iqxos.js → ExecutorForm-Ckr_3kCd.js} +27 -27
- package/lib/{ExecutorForm-Dp7Iqxos.js.map → ExecutorForm-Ckr_3kCd.js.map} +1 -1
- package/lib/FlowDetails-CxTTxsRh.js +10786 -0
- package/lib/FlowDetails-CxTTxsRh.js.map +1 -0
- package/lib/NewOrganization-B8QaQm9K.js +36 -0
- package/lib/{NewOrganization-CQAjr9Dn.js.map → NewOrganization-B8QaQm9K.js.map} +1 -1
- package/lib/PageHeaderClearCachesModal.d.ts +4 -0
- package/lib/{PermissionDetails-xk5HiPzx.js → PermissionDetails-DpwcCYaB.js} +93 -93
- package/lib/{PermissionDetails-xk5HiPzx.js.map → PermissionDetails-DpwcCYaB.js.map} +1 -1
- package/lib/{ResourceDetails-CbJWQn4F.js → ResourceDetails-o5cgUkTJ.js} +30 -30
- package/lib/{ResourceDetails-CbJWQn4F.js.map → ResourceDetails-o5cgUkTJ.js.map} +1 -1
- package/lib/{ScopeDetails-BtYWOGtn.js → ScopeDetails-DgvIDlC8.js} +32 -32
- package/lib/{ScopeDetails-BtYWOGtn.js.map → ScopeDetails-DgvIDlC8.js.map} +1 -1
- package/lib/admin-client.d.ts +1 -1
- package/lib/browser-ponyfill-C_ISF2Ak.js +342 -0
- package/lib/browser-ponyfill-C_ISF2Ak.js.map +1 -0
- package/lib/client-scopes/routes/ClientScope.d.ts +1 -1
- package/lib/client-scopes/routes/Mapper.d.ts +1 -0
- package/lib/clients/routes/Client.d.ts +1 -1
- package/lib/clients/routes/Mapper.d.ts +1 -0
- package/lib/components/dynamic/IntComponent.d.ts +2 -0
- package/lib/components/dynamic/NumberComponent.d.ts +2 -0
- package/lib/components/dynamic/components.d.ts +5 -1
- package/lib/components/json-file-upload/FileUploadForm.d.ts +2 -3
- package/lib/components/role-mapping/RoleMapping.d.ts +1 -1
- package/lib/context/RecentRealms.d.ts +1 -1
- package/lib/context/access/Access.d.ts +1 -1
- package/lib/context/realm-context/RealmContext.d.ts +1 -1
- package/lib/context/server-info/ServerInfoProvider.d.ts +1 -1
- package/lib/context/whoami/WhoAmI.d.ts +1 -1
- package/lib/events/AdminEvents.d.ts +5 -1
- package/lib/groups/MembershipsModal.d.ts +7 -0
- package/lib/identity-providers/routes/IdentityProvider.d.ts +1 -1
- package/lib/index-BJcywEEJ.js +102019 -0
- package/lib/index-BJcywEEJ.js.map +1 -0
- package/lib/index.d.ts +7 -3
- package/lib/keycloak-admin-ui.css +1 -0
- package/lib/keycloak-admin-ui.js +259 -255
- package/lib/organizations/routes/EditOrganization.d.ts +1 -1
- package/lib/permissions/PermissionsSection.d.ts +1 -0
- package/lib/permissions/routes/Permissions.d.ts +7 -0
- package/lib/permissions/routes/PermissionsTabs.d.ts +9 -0
- package/lib/permissions/routes.d.ts +3 -0
- package/lib/realm-roles/routes/RealmRole.d.ts +1 -1
- package/lib/realm-settings/TokensTab.d.ts +1 -2
- package/lib/realm-settings/routes/ThemesTab.d.ts +9 -0
- package/lib/realm-settings/themes/ImageUpload.d.ts +6 -0
- package/lib/realm-settings/themes/LogoContext.d.ts +9 -0
- package/lib/realm-settings/themes/PatternflyVars.d.ts +10 -0
- package/lib/realm-settings/themes/PreviewWindow.d.ts +5 -0
- package/lib/realm-settings/themes/ThemeColors.d.ts +9 -0
- package/lib/realm-settings/{ThemesTab.d.ts → themes/ThemeSettings.d.ts} +2 -2
- package/lib/realm-settings/themes/ThemesTab.d.ts +11 -0
- package/lib/realm-settings/user-profile/UserProfileContext.d.ts +1 -1
- package/lib/realm-settings/user-profile/attribute/AddTranslationsDialog.d.ts +3 -15
- package/lib/realm-settings/user-profile/attribute/AttributeGeneralSettings.d.ts +1 -14
- package/lib/realm-settings/user-profile/attribute/TranslatableField.d.ts +22 -0
- package/lib/theme/login.css +94 -0
- package/lib/user/routes/User.d.ts +1 -1
- package/lib/utils/useCurrentUser.d.ts +5 -5
- package/lib/utils/useIsAdminPermissionsClient.d.ts +1 -0
- package/lib/utils/useIsFeatureEnabled.d.ts +3 -1
- package/package.json +45 -32
- package/LICENSE.txt +0 -202
- package/lib/DetailOrganization-DUNwCft_.js +0 -130
- package/lib/DetailOrganization-DUNwCft_.js.map +0 -1
- package/lib/FlowDetails-SHMxH_Rb.js +0 -10593
- package/lib/FlowDetails-SHMxH_Rb.js.map +0 -1
- package/lib/NewOrganization-CQAjr9Dn.js +0 -36
- package/lib/components/json-file-upload/patternfly/FileUpload.d.ts +0 -73
- package/lib/components/json-file-upload/patternfly/FileUploadField.d.ts +0 -67
- package/lib/components/json-file-upload/patternfly/fileUtils.d.ts +0 -12
- package/lib/index-6gx7hHms.js +0 -66020
- package/lib/index-6gx7hHms.js.map +0 -1
- package/lib/style.css +0 -1
- /package/lib/{clients/scopes → components/copy-to-clipboard-button}/CopyToClipboardButton.d.ts +0 -0
@@ -1,130 +0,0 @@
|
|
1
|
-
import { jsx as t, jsxs as o } from "react/jsx-runtime";
|
2
|
-
import { u as f, U as P, a as p, b9 as O, b as S, o as A, P as c, F, bs as x, bt as B, bu as d, bv as b, c as E, bw as w, A as C, e as k, B as D, bx as R, by as V, bz as j, bA as H, bB as I, bC as U, bD as G } from "./index-6gx7hHms.js";
|
3
|
-
import { useTranslation as K } from "react-i18next";
|
4
|
-
function J() {
|
5
|
-
const { adminClient: m } = f(), { addAlert: u, addError: h } = P(), { realm: g } = p(), { id: r } = O(), { t: a } = K(), e = S(), l = async (i) => {
|
6
|
-
try {
|
7
|
-
const s = H(i);
|
8
|
-
await m.organizations.updateById({ id: r }, s), u(a("organizationSaveSuccess"));
|
9
|
-
} catch (s) {
|
10
|
-
h("organizationSaveError", s);
|
11
|
-
}
|
12
|
-
};
|
13
|
-
A(
|
14
|
-
() => m.organizations.findOne({ id: r }),
|
15
|
-
(i) => {
|
16
|
-
if (!i)
|
17
|
-
throw new Error(a("notFound"));
|
18
|
-
e.reset({
|
19
|
-
...i,
|
20
|
-
domains: i.domains?.map((s) => s.name),
|
21
|
-
attributes: G(i.attributes)
|
22
|
-
});
|
23
|
-
},
|
24
|
-
[r]
|
25
|
-
);
|
26
|
-
const n = (i) => I(
|
27
|
-
U({
|
28
|
-
realm: g,
|
29
|
-
id: r,
|
30
|
-
tab: i
|
31
|
-
})
|
32
|
-
), v = n("settings"), T = n("attributes"), y = n("members"), z = n("identityProviders");
|
33
|
-
return /* @__PURE__ */ t(c, { variant: "light", className: "pf-v5-u-p-0", children: /* @__PURE__ */ o(F, { ...e, children: [
|
34
|
-
/* @__PURE__ */ t(x, { save: () => l(e.getValues()) }),
|
35
|
-
/* @__PURE__ */ o(
|
36
|
-
B,
|
37
|
-
{
|
38
|
-
"data-testid": "organization-tabs",
|
39
|
-
"aria-label": a("organization"),
|
40
|
-
isBox: !0,
|
41
|
-
mountOnEnter: !0,
|
42
|
-
children: [
|
43
|
-
/* @__PURE__ */ t(
|
44
|
-
d,
|
45
|
-
{
|
46
|
-
id: "settings",
|
47
|
-
"data-testid": "settingsTab",
|
48
|
-
title: /* @__PURE__ */ t(b, { children: a("settings") }),
|
49
|
-
...v,
|
50
|
-
children: /* @__PURE__ */ t(c, { children: /* @__PURE__ */ o(
|
51
|
-
E,
|
52
|
-
{
|
53
|
-
role: "anyone",
|
54
|
-
onSubmit: e.handleSubmit(l),
|
55
|
-
isHorizontal: !0,
|
56
|
-
children: [
|
57
|
-
/* @__PURE__ */ t(w, { readOnly: !0 }),
|
58
|
-
/* @__PURE__ */ o(C, { children: [
|
59
|
-
/* @__PURE__ */ t(
|
60
|
-
k,
|
61
|
-
{
|
62
|
-
formState: e.formState,
|
63
|
-
"data-testid": "save",
|
64
|
-
children: a("save")
|
65
|
-
}
|
66
|
-
),
|
67
|
-
/* @__PURE__ */ t(
|
68
|
-
D,
|
69
|
-
{
|
70
|
-
onClick: () => e.reset(),
|
71
|
-
"data-testid": "reset",
|
72
|
-
variant: "link",
|
73
|
-
children: a("reset")
|
74
|
-
}
|
75
|
-
)
|
76
|
-
] })
|
77
|
-
]
|
78
|
-
}
|
79
|
-
) })
|
80
|
-
}
|
81
|
-
),
|
82
|
-
/* @__PURE__ */ t(
|
83
|
-
d,
|
84
|
-
{
|
85
|
-
id: "attributes",
|
86
|
-
"data-testid": "attributeTab",
|
87
|
-
title: /* @__PURE__ */ t(b, { children: a("attributes") }),
|
88
|
-
...T,
|
89
|
-
children: /* @__PURE__ */ t(c, { variant: "light", children: /* @__PURE__ */ t(
|
90
|
-
R,
|
91
|
-
{
|
92
|
-
form: e,
|
93
|
-
save: l,
|
94
|
-
reset: () => e.reset({
|
95
|
-
...e.getValues()
|
96
|
-
}),
|
97
|
-
name: "attributes"
|
98
|
-
}
|
99
|
-
) })
|
100
|
-
}
|
101
|
-
),
|
102
|
-
/* @__PURE__ */ t(
|
103
|
-
d,
|
104
|
-
{
|
105
|
-
id: "members",
|
106
|
-
"data-testid": "membersTab",
|
107
|
-
title: /* @__PURE__ */ t(b, { children: a("members") }),
|
108
|
-
...y,
|
109
|
-
children: /* @__PURE__ */ t(V, {})
|
110
|
-
}
|
111
|
-
),
|
112
|
-
/* @__PURE__ */ t(
|
113
|
-
d,
|
114
|
-
{
|
115
|
-
id: "identityProviders",
|
116
|
-
"data-testid": "identityProvidersTab",
|
117
|
-
title: /* @__PURE__ */ t(b, { children: a("identityProviders") }),
|
118
|
-
...z,
|
119
|
-
children: /* @__PURE__ */ t(j, {})
|
120
|
-
}
|
121
|
-
)
|
122
|
-
]
|
123
|
-
}
|
124
|
-
)
|
125
|
-
] }) });
|
126
|
-
}
|
127
|
-
export {
|
128
|
-
J as default
|
129
|
-
};
|
130
|
-
//# sourceMappingURL=DetailOrganization-DUNwCft_.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"DetailOrganization-DUNwCft_.js","sources":["../src/organizations/DetailOrganization.tsx"],"sourcesContent":["import {\n FormSubmitButton,\n useAlerts,\n useFetch,\n} from \"@keycloak/keycloak-ui-shared\";\nimport {\n ActionGroup,\n Button,\n PageSection,\n Tab,\n TabTitleText,\n} from \"@patternfly/react-core\";\nimport { FormProvider, useForm } from \"react-hook-form\";\nimport { useTranslation } from \"react-i18next\";\nimport { useAdminClient } from \"../admin-client\";\nimport { FormAccess } from \"../components/form/FormAccess\";\nimport { AttributesForm } from \"../components/key-value-form/AttributeForm\";\nimport { arrayToKeyValue } from \"../components/key-value-form/key-value-convert\";\nimport {\n RoutableTabs,\n useRoutableTab,\n} from \"../components/routable-tabs/RoutableTabs\";\nimport { useRealm } from \"../context/realm-context/RealmContext\";\nimport { useParams } from \"../utils/useParams\";\nimport { DetailOrganizationHeader } from \"./DetailOraganzationHeader\";\nimport { IdentityProviders } from \"./IdentityProviders\";\nimport { Members } from \"./Members\";\nimport {\n OrganizationForm,\n OrganizationFormType,\n convertToOrg,\n} from \"./OrganizationForm\";\nimport {\n EditOrganizationParams,\n OrganizationTab,\n toEditOrganization,\n} from \"./routes/EditOrganization\";\n\nexport default function DetailOrganization() {\n const { adminClient } = useAdminClient();\n const { addAlert, addError } = useAlerts();\n\n const { realm } = useRealm();\n const { id } = useParams<EditOrganizationParams>();\n const { t } = useTranslation();\n\n const form = useForm<OrganizationFormType>();\n\n const save = async (org: OrganizationFormType) => {\n try {\n const organization = convertToOrg(org);\n await adminClient.organizations.updateById({ id }, organization);\n addAlert(t(\"organizationSaveSuccess\"));\n } catch (error) {\n addError(\"organizationSaveError\", error);\n }\n };\n\n useFetch(\n () => adminClient.organizations.findOne({ id }),\n (org) => {\n if (!org) {\n throw new Error(t(\"notFound\"));\n }\n form.reset({\n ...org,\n domains: org.domains?.map((d) => d.name),\n attributes: arrayToKeyValue(org.attributes),\n });\n },\n [id],\n );\n\n const useTab = (tab: OrganizationTab) =>\n useRoutableTab(\n toEditOrganization({\n realm,\n id,\n tab,\n }),\n );\n\n const settingsTab = useTab(\"settings\");\n const attributesTab = useTab(\"attributes\");\n const membersTab = useTab(\"members\");\n const identityProvidersTab = useTab(\"identityProviders\");\n\n return (\n <PageSection variant=\"light\" className=\"pf-v5-u-p-0\">\n <FormProvider {...form}>\n <DetailOrganizationHeader save={() => save(form.getValues())} />\n <RoutableTabs\n data-testid=\"organization-tabs\"\n aria-label={t(\"organization\")}\n isBox\n mountOnEnter\n >\n <Tab\n id=\"settings\"\n data-testid=\"settingsTab\"\n title={<TabTitleText>{t(\"settings\")}</TabTitleText>}\n {...settingsTab}\n >\n <PageSection>\n <FormAccess\n role=\"anyone\"\n onSubmit={form.handleSubmit(save)}\n isHorizontal\n >\n <OrganizationForm readOnly />\n <ActionGroup>\n <FormSubmitButton\n formState={form.formState}\n data-testid=\"save\"\n >\n {t(\"save\")}\n </FormSubmitButton>\n <Button\n onClick={() => form.reset()}\n data-testid=\"reset\"\n variant=\"link\"\n >\n {t(\"reset\")}\n </Button>\n </ActionGroup>\n </FormAccess>\n </PageSection>\n </Tab>\n <Tab\n id=\"attributes\"\n data-testid=\"attributeTab\"\n title={<TabTitleText>{t(\"attributes\")}</TabTitleText>}\n {...attributesTab}\n >\n <PageSection variant=\"light\">\n <AttributesForm\n form={form}\n save={save}\n reset={() =>\n form.reset({\n ...form.getValues(),\n })\n }\n name=\"attributes\"\n />\n </PageSection>\n </Tab>\n <Tab\n id=\"members\"\n data-testid=\"membersTab\"\n title={<TabTitleText>{t(\"members\")}</TabTitleText>}\n {...membersTab}\n >\n <Members />\n </Tab>\n <Tab\n id=\"identityProviders\"\n data-testid=\"identityProvidersTab\"\n title={<TabTitleText>{t(\"identityProviders\")}</TabTitleText>}\n {...identityProvidersTab}\n >\n <IdentityProviders />\n </Tab>\n </RoutableTabs>\n </FormProvider>\n </PageSection>\n );\n}\n"],"names":["DetailOrganization","adminClient","useAdminClient","addAlert","addError","useAlerts","realm","useRealm","id","useParams","t","useTranslation","form","useForm","save","org","organization","convertToOrg","error","useFetch","d","arrayToKeyValue","useTab","tab","useRoutableTab","toEditOrganization","settingsTab","attributesTab","membersTab","identityProvidersTab","jsx","PageSection","jsxs","FormProvider","DetailOrganizationHeader","RoutableTabs","Tab","TabTitleText","FormAccess","OrganizationForm","ActionGroup","FormSubmitButton","Button","AttributesForm","Members","IdentityProviders"],"mappings":"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"}
|