@keycloakify/keycloak-account-ui 25.0.4-rc.7 → 26.0.0-rc.0

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.
Files changed (193) hide show
  1. package/KcAccountUiLoader.d.ts +1 -0
  2. package/KcAccountUiLoader.js +2 -1
  3. package/KcAccountUiLoader.js.map +1 -1
  4. package/README.md +19 -19
  5. package/account-security/AccountRow.js +5 -4
  6. package/account-security/AccountRow.js.map +1 -1
  7. package/account-security/DeviceActivity.js +5 -4
  8. package/account-security/DeviceActivity.js.map +1 -1
  9. package/account-security/LinkedAccounts.js +24 -9
  10. package/account-security/LinkedAccounts.js.map +1 -1
  11. package/account-security/LinkedAccountsToolbar.d.ts +12 -0
  12. package/account-security/LinkedAccountsToolbar.js +24 -0
  13. package/account-security/LinkedAccountsToolbar.js.map +1 -0
  14. package/account-security/SigningIn.js +1 -1
  15. package/account-security/SigningIn.js.map +1 -1
  16. package/api/methods.d.ts +7 -1
  17. package/api/methods.js +9 -2
  18. package/api/methods.js.map +1 -1
  19. package/api/parse-links.js +3 -3
  20. package/api/parse-links.js.map +1 -1
  21. package/api/parse-response.d.ts +2 -0
  22. package/api/parse-response.js +11 -15
  23. package/api/parse-response.js.map +1 -1
  24. package/api/request.js +1 -1
  25. package/api/request.js.map +1 -1
  26. package/api.js +1 -7
  27. package/api.js.map +1 -1
  28. package/applications/Applications.js +5 -4
  29. package/applications/Applications.js.map +1 -1
  30. package/environment.d.ts +1 -0
  31. package/environment.js.map +1 -1
  32. package/messages/messages_ca.properties +105 -12
  33. package/messages/messages_de.properties +23 -1
  34. package/messages/messages_en.properties +16 -1
  35. package/messages/messages_es.properties +1 -1
  36. package/messages/messages_fr.properties +64 -19
  37. package/messages/messages_it.properties +3 -0
  38. package/messages/messages_ka.properties +15 -0
  39. package/messages/messages_nl.properties +2 -0
  40. package/organizations/Organizations.d.ts +2 -0
  41. package/organizations/Organizations.js +19 -0
  42. package/organizations/Organizations.js.map +1 -0
  43. package/package.json +89 -29
  44. package/personal-info/PersonalInfo.js +11 -9
  45. package/personal-info/PersonalInfo.js.map +1 -1
  46. package/public/content.d.ts +4 -0
  47. package/public/content.js +5 -0
  48. package/public/content.js.map +1 -1
  49. package/resources/EditTheResource.js +4 -3
  50. package/resources/EditTheResource.js.map +1 -1
  51. package/resources/PermissionRequest.js +4 -3
  52. package/resources/PermissionRequest.js.map +1 -1
  53. package/resources/ResourcesTab.js +4 -3
  54. package/resources/ResourcesTab.js.map +1 -1
  55. package/resources/ShareTheResource.js +4 -3
  56. package/resources/ShareTheResource.js.map +1 -1
  57. package/root/Header.js +1 -1
  58. package/root/Header.js.map +1 -1
  59. package/root/PageNav.js +1 -1
  60. package/root/PageNav.js.map +1 -1
  61. package/routes.d.ts +1 -0
  62. package/routes.js +6 -0
  63. package/routes.js.map +1 -1
  64. package/src/KcAccountUiLoader.tsx +2 -0
  65. package/src/account-security/AccountRow.tsx +6 -8
  66. package/src/account-security/DeviceActivity.tsx +10 -9
  67. package/src/account-security/LinkedAccounts.tsx +107 -30
  68. package/src/account-security/LinkedAccountsToolbar.tsx +88 -0
  69. package/src/account-security/SigningIn.tsx +1 -1
  70. package/src/api/methods.ts +22 -2
  71. package/src/api/parse-links.ts +3 -3
  72. package/src/api/parse-response.ts +22 -23
  73. package/src/api/request.ts +1 -1
  74. package/src/api.ts +1 -7
  75. package/src/applications/Applications.tsx +19 -11
  76. package/src/environment.ts +1 -0
  77. package/src/organizations/Organizations.tsx +48 -0
  78. package/src/personal-info/PersonalInfo.tsx +10 -8
  79. package/src/public/content.ts +5 -0
  80. package/src/resources/EditTheResource.tsx +8 -7
  81. package/src/resources/PermissionRequest.tsx +5 -3
  82. package/src/resources/ResourcesTab.tsx +8 -7
  83. package/src/resources/ShareTheResource.tsx +9 -8
  84. package/src/root/Header.tsx +0 -1
  85. package/src/root/PageNav.tsx +1 -1
  86. package/src/routes.tsx +7 -0
  87. package/src/ui-shared/alerts/AlertPanel.tsx +43 -0
  88. package/src/ui-shared/alerts/Alerts.tsx +48 -52
  89. package/src/ui-shared/context/environment.ts +1 -1
  90. package/src/ui-shared/controls/KeycloakSpinner.tsx +12 -0
  91. package/src/ui-shared/controls/OrganizationTable.tsx +122 -0
  92. package/src/ui-shared/controls/select-control/SingleSelectControl.tsx +3 -1
  93. package/src/ui-shared/controls/select-control/TypeaheadSelectControl.tsx +5 -3
  94. package/src/ui-shared/controls/table/KeycloakDataTable.tsx +597 -0
  95. package/src/ui-shared/controls/table/ListEmptyState.tsx +86 -0
  96. package/src/ui-shared/controls/table/PaginatingTableToolbar.tsx +106 -0
  97. package/src/ui-shared/controls/table/TableToolbar.tsx +92 -0
  98. package/src/ui-shared/main.ts +35 -1
  99. package/src/ui-shared/masthead/Masthead.tsx +64 -48
  100. package/src/ui-shared/select/SingleSelect.tsx +2 -0
  101. package/src/ui-shared/select/TypeaheadSelect.tsx +2 -0
  102. package/src/ui-shared/user-profile/LocaleSelector.tsx +1 -1
  103. package/src/ui-shared/user-profile/UserProfileFields.tsx +18 -21
  104. package/src/ui-shared/user-profile/UserProfileGroup.tsx +3 -2
  105. package/src/ui-shared/user-profile/utils.ts +12 -6
  106. package/src/ui-shared/utils/ErrorBoundary.tsx +77 -0
  107. package/src/ui-shared/utils/darkMode.ts +19 -0
  108. package/src/ui-shared/utils/errors.ts +55 -0
  109. package/src/ui-shared/utils/generateId.ts +1 -0
  110. package/src/ui-shared/utils/useFetch.ts +44 -0
  111. package/src/ui-shared/utils/useSetTimeout.ts +40 -0
  112. package/src/utils/useAccountAlerts.ts +28 -0
  113. package/src/utils/usePromise.ts +8 -3
  114. package/src/zKcContextLike.ts +1 -0
  115. package/ui-shared/alerts/AlertPanel.d.ts +6 -0
  116. package/ui-shared/alerts/AlertPanel.js +6 -0
  117. package/ui-shared/alerts/AlertPanel.js.map +1 -0
  118. package/ui-shared/alerts/Alerts.d.ts +2 -3
  119. package/ui-shared/alerts/Alerts.js +32 -22
  120. package/ui-shared/alerts/Alerts.js.map +1 -1
  121. package/ui-shared/context/environment.js +1 -1
  122. package/ui-shared/context/environment.js.map +1 -1
  123. package/ui-shared/controls/KeycloakSpinner.d.ts +1 -0
  124. package/ui-shared/controls/KeycloakSpinner.js +8 -0
  125. package/ui-shared/controls/KeycloakSpinner.js.map +1 -0
  126. package/ui-shared/controls/OrganizationTable.d.ts +16 -0
  127. package/ui-shared/controls/OrganizationTable.js +45 -0
  128. package/ui-shared/controls/OrganizationTable.js.map +1 -0
  129. package/ui-shared/controls/select-control/SingleSelectControl.js +3 -1
  130. package/ui-shared/controls/select-control/SingleSelectControl.js.map +1 -1
  131. package/ui-shared/controls/select-control/TypeaheadSelectControl.js +5 -3
  132. package/ui-shared/controls/select-control/TypeaheadSelectControl.js.map +1 -1
  133. package/ui-shared/controls/table/KeycloakDataTable.d.ts +64 -0
  134. package/ui-shared/controls/table/KeycloakDataTable.js +279 -0
  135. package/ui-shared/controls/table/KeycloakDataTable.js.map +1 -0
  136. package/ui-shared/controls/table/ListEmptyState.d.ts +20 -0
  137. package/ui-shared/controls/table/ListEmptyState.js +11 -0
  138. package/ui-shared/controls/table/ListEmptyState.js.map +1 -0
  139. package/ui-shared/controls/table/PaginatingTableToolbar.d.ts +21 -0
  140. package/ui-shared/controls/table/PaginatingTableToolbar.js +27 -0
  141. package/ui-shared/controls/table/PaginatingTableToolbar.js.map +1 -0
  142. package/ui-shared/controls/table/TableToolbar.d.ts +12 -0
  143. package/ui-shared/controls/table/TableToolbar.js +30 -0
  144. package/ui-shared/controls/table/TableToolbar.js.map +1 -0
  145. package/ui-shared/main.d.ts +15 -1
  146. package/ui-shared/main.js +13 -1
  147. package/ui-shared/main.js.map +1 -1
  148. package/ui-shared/masthead/Masthead.d.ts +4 -7
  149. package/ui-shared/masthead/Masthead.js +14 -14
  150. package/ui-shared/masthead/Masthead.js.map +1 -1
  151. package/ui-shared/select/SingleSelect.d.ts +1 -1
  152. package/ui-shared/select/SingleSelect.js +2 -2
  153. package/ui-shared/select/SingleSelect.js.map +1 -1
  154. package/ui-shared/select/TypeaheadSelect.d.ts +1 -1
  155. package/ui-shared/select/TypeaheadSelect.js +2 -2
  156. package/ui-shared/select/TypeaheadSelect.js.map +1 -1
  157. package/ui-shared/user-profile/LocaleSelector.js +1 -1
  158. package/ui-shared/user-profile/LocaleSelector.js.map +1 -1
  159. package/ui-shared/user-profile/UserProfileFields.d.ts +2 -4
  160. package/ui-shared/user-profile/UserProfileFields.js +0 -18
  161. package/ui-shared/user-profile/UserProfileFields.js.map +1 -1
  162. package/ui-shared/user-profile/UserProfileGroup.js.map +1 -1
  163. package/ui-shared/user-profile/utils.js +2 -2
  164. package/ui-shared/user-profile/utils.js.map +1 -1
  165. package/ui-shared/utils/ErrorBoundary.d.ts +26 -0
  166. package/ui-shared/utils/ErrorBoundary.js +29 -0
  167. package/ui-shared/utils/ErrorBoundary.js.map +1 -0
  168. package/ui-shared/utils/darkMode.d.ts +1 -0
  169. package/ui-shared/utils/darkMode.js +16 -0
  170. package/ui-shared/utils/darkMode.js.map +1 -0
  171. package/ui-shared/utils/errors.d.ts +4 -0
  172. package/ui-shared/utils/errors.js +42 -0
  173. package/ui-shared/utils/errors.js.map +1 -0
  174. package/ui-shared/utils/generateId.d.ts +1 -0
  175. package/ui-shared/utils/generateId.js +2 -0
  176. package/ui-shared/utils/generateId.js.map +1 -0
  177. package/ui-shared/utils/useFetch.d.ts +17 -0
  178. package/ui-shared/utils/useFetch.js +38 -0
  179. package/ui-shared/utils/useFetch.js.map +1 -0
  180. package/ui-shared/utils/useSetTimeout.d.ts +1 -0
  181. package/ui-shared/utils/useSetTimeout.js +32 -0
  182. package/ui-shared/utils/useSetTimeout.js.map +1 -0
  183. package/utils/useAccountAlerts.d.ts +4 -0
  184. package/utils/useAccountAlerts.js +19 -0
  185. package/utils/useAccountAlerts.js.map +1 -0
  186. package/utils/usePromise.js +7 -3
  187. package/utils/usePromise.js.map +1 -1
  188. package/zKcContextLike.js +1 -0
  189. package/zKcContextLike.js.map +1 -1
  190. package/src/utils/isRecord.ts +0 -2
  191. package/utils/isRecord.d.ts +0 -1
  192. package/utils/isRecord.js +0 -2
  193. package/utils/isRecord.js.map +0 -1
@@ -0,0 +1,279 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
13
+ import { Button, ButtonVariant, ToolbarItem } from "@patternfly/react-core";
14
+ import { ActionsColumn, ExpandableRowContent, Table, TableVariant, Tbody, Td, Th, Thead, Tr, } from "@patternfly/react-table";
15
+ import { cloneDeep, differenceBy, get } from "lodash-es";
16
+ import { isValidElement, useEffect, useId, useMemo, useRef, useState, } from "react";
17
+ import { useTranslation } from "react-i18next";
18
+ import { useStoredState } from "../../../ui-shared/utils/useStoredState";
19
+ import { useFetch } from "../../../ui-shared/utils/useFetch";
20
+ import { ListEmptyState } from "../../../ui-shared/controls/table/ListEmptyState";
21
+ import { PaginatingTableToolbar } from "../../../ui-shared/controls/table/PaginatingTableToolbar";
22
+ import { SyncAltIcon } from "@patternfly/react-icons";
23
+ import { KeycloakSpinner } from "../../../ui-shared/controls/KeycloakSpinner";
24
+ const CellRenderer = ({ row }) => {
25
+ const isRow = (c) => !!c && c.title !== undefined;
26
+ return row.cells.map((c, i) => (_jsx(Td, { children: (isRow(c) ? c.title : c) }, `cell-${i}`)));
27
+ };
28
+ function DataTable(_a) {
29
+ var { columns, rows, actions, actionResolver, ariaLabelKey, onSelect, onCollapse, canSelectAll, isNotCompact, isRadio } = _a, props = __rest(_a, ["columns", "rows", "actions", "actionResolver", "ariaLabelKey", "onSelect", "onCollapse", "canSelectAll", "isNotCompact", "isRadio"]);
30
+ const { t } = useTranslation();
31
+ const [selectedRows, setSelectedRows] = useState([]);
32
+ const [expandedRows, setExpandedRows] = useState([]);
33
+ const updateState = (rowIndex, isSelected) => {
34
+ const items = [
35
+ ...(rowIndex === -1 ? Array(rows.length).fill(isSelected) : selectedRows),
36
+ ];
37
+ items[rowIndex] = isSelected;
38
+ setSelectedRows(items);
39
+ };
40
+ useEffect(() => {
41
+ if (canSelectAll) {
42
+ const selectAllCheckbox = document.getElementsByName("check-all").item(0);
43
+ if (selectAllCheckbox) {
44
+ const checkbox = selectAllCheckbox;
45
+ const selected = selectedRows.filter((r) => r === true);
46
+ checkbox.indeterminate =
47
+ selected.length < rows.length && selected.length > 0;
48
+ }
49
+ }
50
+ }, [selectedRows]);
51
+ return (_jsxs(Table, Object.assign({}, props, { variant: isNotCompact ? undefined : TableVariant.compact, "aria-label": t(ariaLabelKey), children: [_jsx(Thead, { children: _jsxs(Tr, { children: [onCollapse && _jsx(Th, {}), canSelectAll && (_jsx(Th, { select: !isRadio
52
+ ? {
53
+ onSelect: (_, isSelected, rowIndex) => {
54
+ onSelect(isSelected, rowIndex);
55
+ updateState(-1, isSelected);
56
+ },
57
+ isSelected: selectedRows.filter((r) => r === true).length ===
58
+ rows.length,
59
+ }
60
+ : undefined })), columns.map((column) => {
61
+ var _a;
62
+ return (_jsx(Th, { className: (_a = column.transforms) === null || _a === void 0 ? void 0 : _a[0]().className, children: t(column.displayKey || column.name) }, column.displayKey));
63
+ })] }) }), !onCollapse ? (_jsx(Tbody, { children: rows.map((row, index) => (_jsxs(Tr, { isExpanded: expandedRows[index], children: [onSelect && (_jsx(Td, { select: {
64
+ rowIndex: index,
65
+ onSelect: (_, isSelected, rowIndex) => {
66
+ onSelect(isSelected, rowIndex);
67
+ updateState(rowIndex, isSelected);
68
+ },
69
+ isSelected: selectedRows[index],
70
+ variant: isRadio ? "radio" : "checkbox",
71
+ } })), _jsx(CellRenderer, { row: row }), (actions || actionResolver) && (_jsx(Td, { isActionCell: true, children: _jsx(ActionsColumn, { items: actions || (actionResolver === null || actionResolver === void 0 ? void 0 : actionResolver(row, {})), extraData: { rowIndex: index } }) }))] }, index))) })) : (rows.map((row, index) => (_jsx(Tbody, { children: index % 2 === 0 ? (_jsxs(Tr, { children: [_jsx(Td, { expand: {
72
+ isExpanded: !!expandedRows[index],
73
+ rowIndex: index,
74
+ expandId: `${index}`,
75
+ onToggle: (_, rowIndex, isOpen) => {
76
+ onCollapse(isOpen, rowIndex);
77
+ const expand = [...expandedRows];
78
+ expand[index] = isOpen;
79
+ setExpandedRows(expand);
80
+ },
81
+ } }), _jsx(CellRenderer, { row: row })] })) : (_jsxs(Tr, { isExpanded: !!expandedRows[index - 1], children: [_jsx(Td, {}), _jsx(Td, { colSpan: columns.length, children: _jsx(ExpandableRowContent, { children: _jsx(CellRenderer, { row: row }) }) })] })) }, index))))] })));
82
+ }
83
+ /**
84
+ * A generic component that can be used to show the initial list most sections have. Takes care of the loading of the date and filtering.
85
+ * All you have to define is how the columns are displayed.
86
+ * @example
87
+ * <KeycloakDataTable columns={[
88
+ * {
89
+ * name: "clientId", //name of the field from the array of object the loader returns to display in this column
90
+ * displayKey: "clientId", //i18n key to use to lookup the name of the column header
91
+ * cellRenderer: ClientDetailLink, //optionally you can use a component to render the column when you don't want just the content of the field, the whole row / entire object is passed in.
92
+ * }
93
+ * ]}
94
+ * @param {DataListProps} props - The properties.
95
+ * @param {string} props.ariaLabelKey - The aria label key i18n key to lookup the label
96
+ * @param {string} props.searchPlaceholderKey - The i18n key to lookup the placeholder for the search box
97
+ * @param {boolean} props.isPaginated - if true the the loader will be called with first, max and search and a pager will be added in the header
98
+ * @param {(first?: number, max?: number, search?: string) => Promise<T[]>} props.loader - loader function that will fetch the data to display first, max and search are only applicable when isPaginated = true
99
+ * @param {Field<T>} props.columns - definition of the columns
100
+ * @param {Field<T>} props.detailColumns - definition of the columns expandable columns
101
+ * @param {Action[]} props.actions - the actions that appear on the row
102
+ * @param {IActionsResolver} props.actionResolver Resolver for the given action
103
+ * @param {ReactNode} props.toolbarItem - Toolbar items that appear on the top of the table {@link toolbarItem}
104
+ * @param {ReactNode} props.emptyState - ReactNode show when the list is empty could be any component but best to use {@link ListEmptyState}
105
+ */
106
+ export function KeycloakDataTable(_a) {
107
+ var { ariaLabelKey, searchPlaceholderKey, isPaginated = false, onSelect, canSelectAll = false, isNotCompact, isRadio, detailColumns, isRowDisabled, loader, columns, actions, actionResolver, searchTypeComponent, toolbarItem, subToolbar, emptyState, icon, isSearching = false } = _a, props = __rest(_a, ["ariaLabelKey", "searchPlaceholderKey", "isPaginated", "onSelect", "canSelectAll", "isNotCompact", "isRadio", "detailColumns", "isRowDisabled", "loader", "columns", "actions", "actionResolver", "searchTypeComponent", "toolbarItem", "subToolbar", "emptyState", "icon", "isSearching"]);
108
+ const { t } = useTranslation();
109
+ const [selected, setSelected] = useState([]);
110
+ const [rows, setRows] = useState();
111
+ const [unPaginatedData, setUnPaginatedData] = useState();
112
+ const [loading, setLoading] = useState(false);
113
+ const [defaultPageSize, setDefaultPageSize] = useStoredState(localStorage, "pageSize", 10);
114
+ const [max, setMax] = useState(defaultPageSize);
115
+ const [first, setFirst] = useState(0);
116
+ const [search, setSearch] = useState("");
117
+ const prevSearch = useRef();
118
+ const [key, setKey] = useState(0);
119
+ const prevKey = useRef();
120
+ const refresh = () => setKey(key + 1);
121
+ const id = useId();
122
+ const renderCell = (columns, value) => {
123
+ return columns.map((col) => {
124
+ var _a;
125
+ if ("cellFormatters" in col) {
126
+ const v = get(value, col.name);
127
+ return (_a = col.cellFormatters) === null || _a === void 0 ? void 0 : _a.reduce((s, f) => f(s), v);
128
+ }
129
+ if (col.cellRenderer) {
130
+ const Component = col.cellRenderer;
131
+ //@ts-ignore
132
+ return { title: _jsx(Component, Object.assign({}, value)) };
133
+ }
134
+ return get(value, col.name);
135
+ });
136
+ };
137
+ const convertToColumns = (data) => {
138
+ const isDetailColumnsEnabled = (value) => { var _a, _b; return (_b = (_a = detailColumns === null || detailColumns === void 0 ? void 0 : detailColumns[0]) === null || _a === void 0 ? void 0 : _a.enabled) === null || _b === void 0 ? void 0 : _b.call(_a, value); };
139
+ return data
140
+ .map((value, index) => {
141
+ const disabledRow = isRowDisabled ? isRowDisabled(value) : false;
142
+ const row = [
143
+ {
144
+ data: value,
145
+ disableSelection: disabledRow,
146
+ disableActions: disabledRow,
147
+ selected: !!selected.find((v) => get(v, "id") === get(value, "id")),
148
+ isOpen: isDetailColumnsEnabled(value) ? false : undefined,
149
+ cells: renderCell(columns, value),
150
+ },
151
+ ];
152
+ if (detailColumns) {
153
+ row.push({
154
+ parent: index * 2,
155
+ cells: isDetailColumnsEnabled(value)
156
+ ? renderCell(detailColumns, value)
157
+ : [],
158
+ });
159
+ }
160
+ return row;
161
+ })
162
+ .flat();
163
+ };
164
+ const getNodeText = (node) => {
165
+ if (["string", "number"].includes(typeof node)) {
166
+ return node.toString();
167
+ }
168
+ if (node instanceof Array) {
169
+ return node.map(getNodeText).join("");
170
+ }
171
+ if (typeof node === "object") {
172
+ return getNodeText(isValidElement(node.title)
173
+ ? node.title.props
174
+ : Object.values(node));
175
+ }
176
+ return "";
177
+ };
178
+ const filteredData = useMemo(() => search === "" || isPaginated
179
+ ? undefined
180
+ : convertToColumns(unPaginatedData || [])
181
+ .filter((row) => row.cells.some((cell) => cell &&
182
+ getNodeText(cell)
183
+ .toLowerCase()
184
+ .includes(search.toLowerCase())))
185
+ .slice(first, first + max + 1), [search, first, max]);
186
+ useFetch(async () => {
187
+ setLoading(true);
188
+ const newSearch = prevSearch.current === "" && search !== "";
189
+ if (newSearch) {
190
+ setFirst(0);
191
+ }
192
+ prevSearch.current = search;
193
+ return typeof loader === "function"
194
+ ? key === prevKey.current && unPaginatedData
195
+ ? unPaginatedData
196
+ : await loader(newSearch ? 0 : first, max + 1, search)
197
+ : loader;
198
+ }, (data) => {
199
+ prevKey.current = key;
200
+ if (!isPaginated) {
201
+ setUnPaginatedData(data);
202
+ if (data.length > first) {
203
+ data = data.slice(first, first + max + 1);
204
+ }
205
+ else {
206
+ setFirst(0);
207
+ }
208
+ }
209
+ const result = convertToColumns(data);
210
+ setRows(result);
211
+ setLoading(false);
212
+ }, [
213
+ key,
214
+ first,
215
+ max,
216
+ search,
217
+ typeof loader !== "function" ? loader : undefined,
218
+ ]);
219
+ const convertAction = () => actions &&
220
+ cloneDeep(actions).map((action, index) => {
221
+ delete action.onRowClick;
222
+ action.onClick = async (_, rowIndex) => {
223
+ const result = await actions[index].onRowClick((filteredData || rows)[rowIndex].data);
224
+ if (result) {
225
+ if (!isPaginated) {
226
+ setSearch("");
227
+ }
228
+ refresh();
229
+ }
230
+ };
231
+ return action;
232
+ });
233
+ const _onSelect = (isSelected, rowIndex) => {
234
+ const data = filteredData || rows;
235
+ if (rowIndex === -1) {
236
+ setRows(data.map((row) => {
237
+ row.selected = isSelected;
238
+ return row;
239
+ }));
240
+ }
241
+ else {
242
+ data[rowIndex].selected = isSelected;
243
+ setRows([...rows]);
244
+ }
245
+ // Keeps selected items when paginating
246
+ const difference = differenceBy(selected, data.map((row) => row.data), "id");
247
+ // Selected rows are any rows previously selected from a different page, plus current page selections
248
+ const selectedRows = [
249
+ ...difference,
250
+ ...data.filter((row) => row.selected).map((row) => row.data),
251
+ ];
252
+ setSelected(selectedRows);
253
+ onSelect(selectedRows);
254
+ };
255
+ const onCollapse = (isOpen, rowIndex) => {
256
+ data[rowIndex].isOpen = isOpen;
257
+ setRows([...data]);
258
+ };
259
+ const data = filteredData || rows;
260
+ const noData = !data || data.length === 0;
261
+ const searching = search !== "" || isSearching;
262
+ // if we use detail columns there are twice the number of rows
263
+ const maxRows = detailColumns ? max * 2 : max;
264
+ const rowLength = detailColumns ? ((data === null || data === void 0 ? void 0 : data.length) || 0) / 2 : (data === null || data === void 0 ? void 0 : data.length) || 0;
265
+ return (_jsxs(_Fragment, { children: [(loading || !noData || searching) && (_jsxs(PaginatingTableToolbar, { id: id, count: rowLength, first: first, max: max, onNextClick: setFirst, onPreviousClick: setFirst, onPerPageSelect: (first, max) => {
266
+ setFirst(first);
267
+ setMax(max);
268
+ setDefaultPageSize(max);
269
+ }, inputGroupName: searchPlaceholderKey ? `${ariaLabelKey}input` : undefined, inputGroupOnEnter: setSearch, inputGroupPlaceholder: t(searchPlaceholderKey || ""), searchTypeComponent: searchTypeComponent, toolbarItem: _jsxs(_Fragment, { children: [toolbarItem, " ", _jsx(ToolbarItem, { variant: "separator" }), " ", _jsx(ToolbarItem, { children: _jsxs(Button, { variant: "link", onClick: refresh, children: [_jsx(SyncAltIcon, {}), " ", t("refresh")] }) })] }), subToolbar: subToolbar, children: [!loading && !noData && (_jsx(DataTable, Object.assign({}, props, { canSelectAll: canSelectAll, onSelect: onSelect ? _onSelect : undefined, onCollapse: detailColumns ? onCollapse : undefined, actions: convertAction(), actionResolver: actionResolver, rows: data.slice(0, maxRows), columns: columns, isNotCompact: isNotCompact, isRadio: isRadio, ariaLabelKey: ariaLabelKey }))), !loading && noData && searching && (_jsx(ListEmptyState, { hasIcon: true, icon: icon, isSearchVariant: true, message: t("noSearchResults"), instructions: t("noSearchResultsInstructions"), secondaryActions: !isSearching
270
+ ? [
271
+ {
272
+ text: t("clearAllFilters"),
273
+ onClick: () => setSearch(""),
274
+ type: ButtonVariant.link,
275
+ },
276
+ ]
277
+ : [] })), loading && _jsx(KeycloakSpinner, {})] })), !loading && noData && !searching && emptyState] }));
278
+ }
279
+ //# sourceMappingURL=KeycloakDataTable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"KeycloakDataTable.js","sourceRoot":"","sources":["../../../src/ui-shared/controls/table/KeycloakDataTable.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,20 @@
1
+ import { ComponentClass, MouseEventHandler, ReactNode } from "react";
2
+ import { ButtonVariant } from "@patternfly/react-core";
3
+ import type { SVGIconProps } from "@patternfly/react-icons/dist/js/createIcon";
4
+ export type Action = {
5
+ text: string;
6
+ type?: ButtonVariant;
7
+ onClick: MouseEventHandler<HTMLButtonElement>;
8
+ };
9
+ export type ListEmptyStateProps = {
10
+ message: string;
11
+ instructions: ReactNode;
12
+ primaryActionText?: string;
13
+ onPrimaryAction?: MouseEventHandler<HTMLButtonElement>;
14
+ hasIcon?: boolean;
15
+ icon?: ComponentClass<SVGIconProps>;
16
+ isSearchVariant?: boolean;
17
+ secondaryActions?: Action[];
18
+ isDisabled?: boolean;
19
+ };
20
+ export declare const ListEmptyState: ({ message, instructions, onPrimaryAction, hasIcon, isSearchVariant, primaryActionText, secondaryActions, icon, isDisabled, }: ListEmptyStateProps) => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { EmptyState, EmptyStateIcon, EmptyStateBody, Button, ButtonVariant, EmptyStateActions, EmptyStateHeader, EmptyStateFooter, } from "@patternfly/react-core";
3
+ import { PlusCircleIcon, SearchIcon } from "@patternfly/react-icons";
4
+ export const ListEmptyState = ({ message, instructions, onPrimaryAction, hasIcon = true, isSearchVariant, primaryActionText, secondaryActions, icon, isDisabled = false, }) => {
5
+ return (_jsxs(EmptyState, { "data-testid": "empty-state", variant: "lg", children: [hasIcon && isSearchVariant ? (_jsx(EmptyStateIcon, { icon: SearchIcon })) : (hasIcon && _jsx(EmptyStateIcon, { icon: icon ? icon : PlusCircleIcon })), _jsx(EmptyStateHeader, { titleText: message, headingLevel: "h1" }), _jsx(EmptyStateBody, { children: instructions }), _jsxs(EmptyStateFooter, { children: [primaryActionText && (_jsx(Button, { "data-testid": `${message
6
+ .replace(/\W+/g, "-")
7
+ .toLowerCase()}-empty-action`, variant: "primary", onClick: onPrimaryAction, isDisabled: isDisabled, children: primaryActionText })), secondaryActions && (_jsx(EmptyStateActions, { children: secondaryActions.map((action) => (_jsx(Button, { "data-testid": `${action.text
8
+ .replace(/\W+/g, "-")
9
+ .toLowerCase()}-empty-action`, variant: action.type || ButtonVariant.secondary, onClick: action.onClick, isDisabled: isDisabled, children: action.text }, action.text))) }))] })] }));
10
+ };
11
+ //# sourceMappingURL=ListEmptyState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListEmptyState.js","sourceRoot":"","sources":["../../../src/ui-shared/controls/table/ListEmptyState.tsx"],"names":[],"mappings":";AACA,OAAO,EACL,UAAU,EACV,cAAc,EACd,cAAc,EACd,MAAM,EACN,aAAa,EACb,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,GACjB,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,cAAc,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAoBrE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,OAAO,EACP,YAAY,EACZ,eAAe,EACf,OAAO,GAAG,IAAI,EACd,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EAChB,IAAI,EACJ,UAAU,GAAG,KAAK,GACE,EAAE,EAAE;IACxB,OAAO,CACL,MAAC,UAAU,mBAAa,aAAa,EAAC,OAAO,EAAC,IAAI,aAC/C,OAAO,IAAI,eAAe,CAAC,CAAC,CAAC,CAC5B,KAAC,cAAc,IAAC,IAAI,EAAE,UAAU,GAAI,CACrC,CAAC,CAAC,CAAC,CACF,OAAO,IAAI,KAAC,cAAc,IAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,GAAI,CAClE,EACD,KAAC,gBAAgB,IAAC,SAAS,EAAE,OAAO,EAAE,YAAY,EAAC,IAAI,GAAG,EAC1D,KAAC,cAAc,cAAE,YAAY,GAAkB,EAC/C,MAAC,gBAAgB,eACd,iBAAiB,IAAI,CACpB,KAAC,MAAM,mBACQ,GAAG,OAAO;6BACpB,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;6BACpB,WAAW,EAAE,eAAe,EAC/B,OAAO,EAAC,SAAS,EACjB,OAAO,EAAE,eAAe,EACxB,UAAU,EAAE,UAAU,YAErB,iBAAiB,GACX,CACV,EACA,gBAAgB,IAAI,CACnB,KAAC,iBAAiB,cACf,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAChC,KAAC,MAAM,mBAEQ,GAAG,MAAM,CAAC,IAAI;iCACxB,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC;iCACpB,WAAW,EAAE,eAAe,EAC/B,OAAO,EAAE,MAAM,CAAC,IAAI,IAAI,aAAa,CAAC,SAAS,EAC/C,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,UAAU,EAAE,UAAU,YAErB,MAAM,CAAC,IAAI,IARP,MAAM,CAAC,IAAI,CAST,CACV,CAAC,GACgB,CACrB,IACgB,IACR,CACd,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,21 @@
1
+ import { PropsWithChildren, ReactNode } from "react";
2
+ type KeycloakPaginationProps = {
3
+ id?: string;
4
+ count: number;
5
+ first: number;
6
+ max: number;
7
+ onNextClick: (page: number) => void;
8
+ onPreviousClick: (page: number) => void;
9
+ onPerPageSelect: (max: number, first: number) => void;
10
+ variant?: "top" | "bottom";
11
+ };
12
+ type TableToolbarProps = KeycloakPaginationProps & {
13
+ searchTypeComponent?: ReactNode;
14
+ toolbarItem?: ReactNode;
15
+ subToolbar?: ReactNode;
16
+ inputGroupName?: string;
17
+ inputGroupPlaceholder?: string;
18
+ inputGroupOnEnter?: (value: string) => void;
19
+ };
20
+ export declare const PaginatingTableToolbar: ({ count, searchTypeComponent, toolbarItem, subToolbar, children, inputGroupName, inputGroupPlaceholder, inputGroupOnEnter, ...rest }: PropsWithChildren<TableToolbarProps>) => import("react/jsx-runtime").JSX.Element;
21
+ export {};
@@ -0,0 +1,27 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsxs as _jsxs, jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
13
+ import { Pagination, ToolbarItem, } from "@patternfly/react-core";
14
+ import { useTranslation } from "react-i18next";
15
+ import { TableToolbar } from "../../../ui-shared/controls/table/TableToolbar";
16
+ const KeycloakPagination = ({ id, variant = "top", count, first, max, onNextClick, onPreviousClick, onPerPageSelect, }) => {
17
+ const { t } = useTranslation();
18
+ const page = Math.round(first / max);
19
+ return (_jsx(Pagination, { widgetId: id, titles: {
20
+ paginationAriaLabel: `${t("pagination")} ${variant} `,
21
+ }, isCompact: true, toggleTemplate: ({ firstIndex, lastIndex, }) => (_jsxs("b", { children: [firstIndex, " - ", lastIndex] })), itemCount: count + page * max, page: page + 1, perPage: max, onNextClick: (_, p) => onNextClick((p - 1) * max), onPreviousClick: (_, p) => onPreviousClick((p - 1) * max), onPerPageSelect: (_, m, f) => onPerPageSelect(f - 1, m), variant: variant }));
22
+ };
23
+ export const PaginatingTableToolbar = (_a) => {
24
+ var { count, searchTypeComponent, toolbarItem, subToolbar, children, inputGroupName, inputGroupPlaceholder, inputGroupOnEnter } = _a, rest = __rest(_a, ["count", "searchTypeComponent", "toolbarItem", "subToolbar", "children", "inputGroupName", "inputGroupPlaceholder", "inputGroupOnEnter"]);
25
+ return (_jsx(TableToolbar, { searchTypeComponent: searchTypeComponent, toolbarItem: _jsxs(_Fragment, { children: [toolbarItem, _jsx(ToolbarItem, { variant: "pagination", children: _jsx(KeycloakPagination, Object.assign({ count: count }, rest)) })] }), subToolbar: subToolbar, toolbarItemFooter: count !== 0 ? (_jsx(ToolbarItem, { variant: "pagination", children: _jsx(KeycloakPagination, Object.assign({ count: count, variant: "bottom" }, rest)) })) : null, inputGroupName: inputGroupName, inputGroupPlaceholder: inputGroupPlaceholder, inputGroupOnEnter: inputGroupOnEnter, children: children }));
26
+ };
27
+ //# sourceMappingURL=PaginatingTableToolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PaginatingTableToolbar.js","sourceRoot":"","sources":["../../../src/ui-shared/controls/table/PaginatingTableToolbar.tsx"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EACL,UAAU,EAEV,WAAW,GACZ,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,OAAO,EAAE,YAAY,EAAE,MAAM,wEAAwE,CAAC;AAsBtG,MAAM,kBAAkB,GAAG,CAAC,EAC1B,EAAE,EACF,OAAO,GAAG,KAAK,EACf,KAAK,EACL,KAAK,EACL,GAAG,EACH,WAAW,EACX,eAAe,EACf,eAAe,GACS,EAAE,EAAE;IAC5B,MAAM,EAAE,CAAC,EAAE,GAAG,cAAc,EAAE,CAAC;IAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;IACrC,OAAO,CACL,KAAC,UAAU,IACT,QAAQ,EAAE,EAAE,EACZ,MAAM,EAAE;YACN,mBAAmB,EAAE,GAAG,CAAC,CAAC,YAAY,CAAC,IAAI,OAAO,GAAG;SACtD,EACD,SAAS,QACT,cAAc,EAAE,CAAC,EACf,UAAU,EACV,SAAS,GACqB,EAAE,EAAE,CAAC,CACnC,wBACG,UAAU,SAAK,SAAS,IACvB,CACL,EACD,SAAS,EAAE,KAAK,GAAG,IAAI,GAAG,GAAG,EAC7B,IAAI,EAAE,IAAI,GAAG,CAAC,EACd,OAAO,EAAE,GAAG,EACZ,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACjD,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACzD,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,EACvD,OAAO,EAAE,OAAO,GAChB,CACH,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,EAUA,EAAE,EAAE;QAVJ,EACrC,KAAK,EACL,mBAAmB,EACnB,WAAW,EACX,UAAU,EACV,QAAQ,EACR,cAAc,EACd,qBAAqB,EACrB,iBAAiB,OAEoB,EADlC,IAAI,cAT8B,yIAUtC,CADQ;IAEP,OAAO,CACL,KAAC,YAAY,IACX,mBAAmB,EAAE,mBAAmB,EACxC,WAAW,EACT,8BACG,WAAW,EACZ,KAAC,WAAW,IAAC,OAAO,EAAC,YAAY,YAC/B,KAAC,kBAAkB,kBAAC,KAAK,EAAE,KAAK,IAAM,IAAI,EAAI,GAClC,IACb,EAEL,UAAU,EAAE,UAAU,EACtB,iBAAiB,EACf,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,CACZ,KAAC,WAAW,IAAC,OAAO,EAAC,YAAY,YAC/B,KAAC,kBAAkB,kBAAC,KAAK,EAAE,KAAK,EAAE,OAAO,EAAC,QAAQ,IAAK,IAAI,EAAI,GACnD,CACf,CAAC,CAAC,CAAC,IAAI,EAEV,cAAc,EAAE,cAAc,EAC9B,qBAAqB,EAAE,qBAAqB,EAC5C,iBAAiB,EAAE,iBAAiB,YAEnC,QAAQ,GACI,CAChB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { PropsWithChildren, ReactNode } from "react";
2
+ type TableToolbarProps = {
3
+ toolbarItem?: ReactNode;
4
+ subToolbar?: ReactNode;
5
+ toolbarItemFooter?: ReactNode;
6
+ searchTypeComponent?: ReactNode;
7
+ inputGroupName?: string;
8
+ inputGroupPlaceholder?: string;
9
+ inputGroupOnEnter?: (value: string) => void;
10
+ };
11
+ export declare const TableToolbar: ({ toolbarItem, subToolbar, toolbarItemFooter, children, searchTypeComponent, inputGroupName, inputGroupPlaceholder, inputGroupOnEnter, }: PropsWithChildren<TableToolbarProps>) => import("react/jsx-runtime").JSX.Element;
12
+ export {};
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { Divider, InputGroup, SearchInput, Toolbar, ToolbarContent, ToolbarItem, } from "@patternfly/react-core";
3
+ import { useState } from "react";
4
+ import { useTranslation } from "react-i18next";
5
+ export const TableToolbar = ({ toolbarItem, subToolbar, toolbarItemFooter, children, searchTypeComponent, inputGroupName, inputGroupPlaceholder, inputGroupOnEnter, }) => {
6
+ const { t } = useTranslation();
7
+ const [searchValue, setSearchValue] = useState("");
8
+ const onSearch = () => {
9
+ if (searchValue !== "") {
10
+ setSearchValue(searchValue);
11
+ inputGroupOnEnter === null || inputGroupOnEnter === void 0 ? void 0 : inputGroupOnEnter(searchValue);
12
+ }
13
+ else {
14
+ setSearchValue("");
15
+ inputGroupOnEnter === null || inputGroupOnEnter === void 0 ? void 0 : inputGroupOnEnter("");
16
+ }
17
+ };
18
+ const handleKeyDown = (e) => {
19
+ if (e.key === "Enter") {
20
+ onSearch();
21
+ }
22
+ };
23
+ return (_jsxs(_Fragment, { children: [_jsx(Toolbar, { children: _jsxs(ToolbarContent, { children: [inputGroupName && (_jsx(ToolbarItem, { children: _jsxs(InputGroup, { "data-testid": inputGroupName, children: [searchTypeComponent, inputGroupPlaceholder && (_jsx(SearchInput, { "data-testid": "table-search-input", placeholder: inputGroupPlaceholder, "aria-label": t("search"), value: searchValue, onChange: (_, value) => {
24
+ setSearchValue(value);
25
+ }, onSearch: onSearch, onKeyDown: handleKeyDown, onClear: () => {
26
+ setSearchValue("");
27
+ inputGroupOnEnter === null || inputGroupOnEnter === void 0 ? void 0 : inputGroupOnEnter("");
28
+ } }))] }) })), toolbarItem] }) }), subToolbar && (_jsx(Toolbar, { children: _jsx(ToolbarContent, { children: subToolbar }) })), _jsx(Divider, {}), children, _jsx(Toolbar, { children: toolbarItemFooter })] }));
29
+ };
30
+ //# sourceMappingURL=TableToolbar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableToolbar.js","sourceRoot":"","sources":["../../../src/ui-shared/controls/table/TableToolbar.tsx"],"names":[],"mappings":";AAAA,OAAO,EACL,OAAO,EACP,UAAU,EACV,WAAW,EACX,OAAO,EACP,cAAc,EACd,WAAW,GACZ,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAA+C,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAY/C,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAC3B,WAAW,EACX,UAAU,EACV,iBAAiB,EACjB,QAAQ,EACR,mBAAmB,EACnB,cAAc,EACd,qBAAqB,EACrB,iBAAiB,GACoB,EAAE,EAAE;IACzC,MAAM,EAAE,CAAC,EAAE,GAAG,cAAc,EAAE,CAAC;IAC/B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAS,EAAE,CAAC,CAAC;IAE3D,MAAM,QAAQ,GAAG,GAAG,EAAE;QACpB,IAAI,WAAW,KAAK,EAAE,EAAE,CAAC;YACvB,cAAc,CAAC,WAAW,CAAC,CAAC;YAC5B,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAG,WAAW,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,cAAc,CAAC,EAAE,CAAC,CAAC;YACnB,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAG,EAAE,CAAC,CAAC;QAC1B,CAAC;IACH,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,CAAC,CAAkC,EAAE,EAAE;QAC3D,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YACtB,QAAQ,EAAE,CAAC;QACb,CAAC;IACH,CAAC,CAAC;IAEF,OAAO,CACL,8BACE,KAAC,OAAO,cACN,MAAC,cAAc,eACZ,cAAc,IAAI,CACjB,KAAC,WAAW,cACV,MAAC,UAAU,mBAAc,cAAc,aACpC,mBAAmB,EACnB,qBAAqB,IAAI,CACxB,KAAC,WAAW,mBACE,oBAAoB,EAChC,WAAW,EAAE,qBAAqB,gBACtB,CAAC,CAAC,QAAQ,CAAC,EACvB,KAAK,EAAE,WAAW,EAClB,QAAQ,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;4CACrB,cAAc,CAAC,KAAK,CAAC,CAAC;wCACxB,CAAC,EACD,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,aAAa,EACxB,OAAO,EAAE,GAAG,EAAE;4CACZ,cAAc,CAAC,EAAE,CAAC,CAAC;4CACnB,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAG,EAAE,CAAC,CAAC;wCAC1B,CAAC,GACD,CACH,IACU,GACD,CACf,EACA,WAAW,IACG,GACT,EACT,UAAU,IAAI,CACb,KAAC,OAAO,cACN,KAAC,cAAc,cAAE,UAAU,GAAkB,GACrC,CACX,EACD,KAAC,OAAO,KAAG,EACV,QAAQ,EACT,KAAC,OAAO,cAAE,iBAAiB,GAAW,IACrC,CACJ,CAAC;AACJ,CAAC,CAAC"}
@@ -1,4 +1,4 @@
1
- export { AlertProvider, useAlerts } from "../ui-shared/alerts/Alerts";
1
+ export { AlertProvider, useAlerts, type AddAlertFunction, type AddErrorFunction, type AlertProps, } from "../ui-shared/alerts/Alerts";
2
2
  export { ErrorPage } from "../ui-shared/context/ErrorPage";
3
3
  export { Help, useHelp } from "../ui-shared/context/HelpContext";
4
4
  export { KeycloakProvider, useEnvironment, type KeycloakContext, } from "../ui-shared/context/KeycloakContext";
@@ -23,9 +23,23 @@ export { UserProfileFields } from "../ui-shared/user-profile/UserProfileFields";
23
23
  export { beerify, debeerify, isUserProfileError, label, setUserProfileServerError, } from "../ui-shared/user-profile/utils";
24
24
  export type { UserFormFields } from "../ui-shared/user-profile/utils";
25
25
  export { createNamedContext } from "../ui-shared/utils/createNamedContext";
26
+ export { getErrorDescription, getErrorMessage, getNetworkErrorMessage, getNetworkErrorDescription, } from "../ui-shared/utils/errors";
26
27
  export { isDefined } from "../ui-shared/utils/isDefined";
27
28
  export { useRequiredContext } from "../ui-shared/utils/useRequiredContext";
28
29
  export { useStoredState } from "../ui-shared/utils/useStoredState";
30
+ export { useSetTimeout } from "../ui-shared/utils/useSetTimeout";
31
+ export { generateId } from "../ui-shared/utils/generateId";
29
32
  export { default as KeycloakMasthead } from "../ui-shared/masthead/Masthead";
30
33
  export { KeycloakSelect } from "../ui-shared/select/KeycloakSelect";
31
34
  export type { Variant, KeycloakSelectProps } from "../ui-shared/select/KeycloakSelect";
35
+ export { KeycloakDataTable } from "../ui-shared/controls/table/KeycloakDataTable";
36
+ export type { Action, Field, DetailField, LoaderFunction, } from "../ui-shared/controls/table/KeycloakDataTable";
37
+ export { PaginatingTableToolbar } from "../ui-shared/controls/table/PaginatingTableToolbar";
38
+ export { TableToolbar } from "../ui-shared/controls/table/TableToolbar";
39
+ export { ListEmptyState } from "../ui-shared/controls/table/ListEmptyState";
40
+ export { KeycloakSpinner } from "../ui-shared/controls/KeycloakSpinner";
41
+ export { useFetch } from "../ui-shared/utils/useFetch";
42
+ export { useErrorBoundary, ErrorBoundaryFallback, ErrorBoundaryProvider, } from "../ui-shared/utils/ErrorBoundary";
43
+ export type { FallbackProps } from "../ui-shared/utils/ErrorBoundary";
44
+ export { OrganizationTable } from "../ui-shared/controls/OrganizationTable";
45
+ export { initializeDarkMode } from "../ui-shared/utils/darkMode";
package/ui-shared/main.js CHANGED
@@ -1,4 +1,4 @@
1
- export { AlertProvider, useAlerts } from "../ui-shared/alerts/Alerts";
1
+ export { AlertProvider, useAlerts, } from "../ui-shared/alerts/Alerts";
2
2
  export { ErrorPage } from "../ui-shared/context/ErrorPage";
3
3
  export { Help, useHelp } from "../ui-shared/context/HelpContext";
4
4
  export { KeycloakProvider, useEnvironment, } from "../ui-shared/context/KeycloakContext";
@@ -21,9 +21,21 @@ export { FormSubmitButton, } from "../ui-shared/buttons/FormSubmitButton";
21
21
  export { UserProfileFields } from "../ui-shared/user-profile/UserProfileFields";
22
22
  export { beerify, debeerify, isUserProfileError, label, setUserProfileServerError, } from "../ui-shared/user-profile/utils";
23
23
  export { createNamedContext } from "../ui-shared/utils/createNamedContext";
24
+ export { getErrorDescription, getErrorMessage, getNetworkErrorMessage, getNetworkErrorDescription, } from "../ui-shared/utils/errors";
24
25
  export { isDefined } from "../ui-shared/utils/isDefined";
25
26
  export { useRequiredContext } from "../ui-shared/utils/useRequiredContext";
26
27
  export { useStoredState } from "../ui-shared/utils/useStoredState";
28
+ export { useSetTimeout } from "../ui-shared/utils/useSetTimeout";
29
+ export { generateId } from "../ui-shared/utils/generateId";
27
30
  export { default as KeycloakMasthead } from "../ui-shared/masthead/Masthead";
28
31
  export { KeycloakSelect } from "../ui-shared/select/KeycloakSelect";
32
+ export { KeycloakDataTable } from "../ui-shared/controls/table/KeycloakDataTable";
33
+ export { PaginatingTableToolbar } from "../ui-shared/controls/table/PaginatingTableToolbar";
34
+ export { TableToolbar } from "../ui-shared/controls/table/TableToolbar";
35
+ export { ListEmptyState } from "../ui-shared/controls/table/ListEmptyState";
36
+ export { KeycloakSpinner } from "../ui-shared/controls/KeycloakSpinner";
37
+ export { useFetch } from "../ui-shared/utils/useFetch";
38
+ export { useErrorBoundary, ErrorBoundaryFallback, ErrorBoundaryProvider, } from "../ui-shared/utils/ErrorBoundary";
39
+ export { OrganizationTable } from "../ui-shared/controls/OrganizationTable";
40
+ export { initializeDarkMode } from "../ui-shared/utils/darkMode";
29
41
  //# sourceMappingURL=main.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/ui-shared/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,0DAA0D,CAAC;AACpG,OAAO,EAAE,SAAS,EAAE,MAAM,8DAA8D,CAAC;AACzF,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,gEAAgE,CAAC;AAC/F,OAAO,EACL,gBAAgB,EAChB,cAAc,GAEf,MAAM,oEAAoE,CAAC;AAC5E,OAAO,EACL,sBAAsB,GAEvB,MAAM,gEAAgE,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gFAAgF,CAAC;AACrH,OAAO,EACL,aAAa,GAEd,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAE,QAAQ,EAAE,MAAM,8DAA8D,CAAC;AACxF,OAAO,EAAE,aAAa,EAAE,MAAM,mEAAmE,CAAC;AAClG,OAAO,EAAE,eAAe,EAAE,MAAM,qEAAqE,CAAC;AACtG,OAAO,EAAE,aAAa,EAAE,MAAM,mEAAmE,CAAC;AAClG,OAAO,EACL,aAAa,EACb,aAAa,GACd,MAAM,kFAAkF,CAAC;AAK1F,OAAO,EACL,aAAa,GAEd,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,qEAAqE,CAAC;AACtG,OAAO,EAAE,WAAW,EAAE,MAAM,iEAAiE,CAAC;AAC9F,OAAO,EACL,gBAAgB,GAEjB,MAAM,yFAAyF,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,6DAA6D,CAAC;AACzF,OAAO,EAAE,SAAS,EAAE,MAAM,kEAAkE,CAAC;AAC7F,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,mEAAmE,CAAC;AAClH,OAAO,EACL,gBAAgB,GAEjB,MAAM,qEAAqE,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,2EAA2E,CAAC;AAC9G,OAAO,EACL,OAAO,EACP,SAAS,EACT,kBAAkB,EAClB,KAAK,EACL,yBAAyB,GAC1B,MAAM,+DAA+D,CAAC;AAEvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,qEAAqE,CAAC;AACzG,OAAO,EAAE,SAAS,EAAE,MAAM,4DAA4D,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,qEAAqE,CAAC;AACzG,OAAO,EAAE,cAAc,EAAE,MAAM,iEAAiE,CAAC;AACjG,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,8DAA8D,CAAC;AAC3G,OAAO,EAAE,cAAc,EAAE,MAAM,kEAAkE,CAAC"}
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../src/ui-shared/main.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,SAAS,GAIV,MAAM,0DAA0D,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,8DAA8D,CAAC;AACzF,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,gEAAgE,CAAC;AAC/F,OAAO,EACL,gBAAgB,EAChB,cAAc,GAEf,MAAM,oEAAoE,CAAC;AAC5E,OAAO,EACL,sBAAsB,GAEvB,MAAM,gEAAgE,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,gFAAgF,CAAC;AACrH,OAAO,EACL,aAAa,GAEd,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAE,QAAQ,EAAE,MAAM,8DAA8D,CAAC;AACxF,OAAO,EAAE,aAAa,EAAE,MAAM,mEAAmE,CAAC;AAClG,OAAO,EAAE,eAAe,EAAE,MAAM,qEAAqE,CAAC;AACtG,OAAO,EAAE,aAAa,EAAE,MAAM,mEAAmE,CAAC;AAClG,OAAO,EACL,aAAa,EACb,aAAa,GACd,MAAM,kFAAkF,CAAC;AAK1F,OAAO,EACL,aAAa,GAEd,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,qEAAqE,CAAC;AACtG,OAAO,EAAE,WAAW,EAAE,MAAM,iEAAiE,CAAC;AAC9F,OAAO,EACL,gBAAgB,GAEjB,MAAM,yFAAyF,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,6DAA6D,CAAC;AACzF,OAAO,EAAE,SAAS,EAAE,MAAM,kEAAkE,CAAC;AAC7F,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,mEAAmE,CAAC;AAClH,OAAO,EACL,gBAAgB,GAEjB,MAAM,qEAAqE,CAAC;AAC7E,OAAO,EAAE,iBAAiB,EAAE,MAAM,2EAA2E,CAAC;AAC9G,OAAO,EACL,OAAO,EACP,SAAS,EACT,kBAAkB,EAClB,KAAK,EACL,yBAAyB,GAC1B,MAAM,+DAA+D,CAAC;AAEvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,qEAAqE,CAAC;AACzG,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,sBAAsB,EACtB,0BAA0B,GAC3B,MAAM,yDAAyD,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,4DAA4D,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,MAAM,qEAAqE,CAAC;AACzG,OAAO,EAAE,cAAc,EAAE,MAAM,iEAAiE,CAAC;AACjG,OAAO,EAAE,aAAa,EAAE,MAAM,gEAAgE,CAAC;AAC/F,OAAO,EAAE,UAAU,EAAE,MAAM,6DAA6D,CAAC;AACzF,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,8DAA8D,CAAC;AAC3G,OAAO,EAAE,cAAc,EAAE,MAAM,kEAAkE,CAAC;AAElG,OAAO,EAAE,iBAAiB,EAAE,MAAM,6EAA6E,CAAC;AAOhH,OAAO,EAAE,sBAAsB,EAAE,MAAM,kFAAkF,CAAC;AAC1H,OAAO,EAAE,YAAY,EAAE,MAAM,wEAAwE,CAAC;AACtG,OAAO,EAAE,cAAc,EAAE,MAAM,0EAA0E,CAAC;AAC1G,OAAO,EAAE,eAAe,EAAE,MAAM,qEAAqE,CAAC;AACtG,OAAO,EAAE,QAAQ,EAAE,MAAM,2DAA2D,CAAC;AACrF,OAAO,EACL,gBAAgB,EAChB,qBAAqB,EACrB,qBAAqB,GACtB,MAAM,gEAAgE,CAAC;AAExE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uEAAuE,CAAC;AAC1G,OAAO,EAAE,kBAAkB,EAAE,MAAM,2DAA2D,CAAC"}
@@ -1,11 +1,8 @@
1
- import { AvatarProps, BrandProps } from "@patternfly/react-core";
2
- import { PageHeaderProps } from "@patternfly/react-core/deprecated";
1
+ import { AvatarProps, MastheadBrandProps, MastheadMainProps } from "@patternfly/react-core";
3
2
  import Keycloak from "keycloak-js";
4
3
  import { ReactNode } from "react";
5
- type BrandLogo = BrandProps & {
6
- href: string;
7
- };
8
- type KeycloakMastheadProps = PageHeaderProps & {
4
+ type BrandLogo = MastheadBrandProps;
5
+ type KeycloakMastheadProps = MastheadMainProps & {
9
6
  keycloak: Keycloak;
10
7
  brand: BrandLogo;
11
8
  avatar?: AvatarProps;
@@ -18,5 +15,5 @@ type KeycloakMastheadProps = PageHeaderProps & {
18
15
  dropdownItems?: ReactNode[];
19
16
  toolbarItems?: ReactNode[];
20
17
  };
21
- declare const KeycloakMasthead: ({ keycloak, brand: { href: brandHref, ...brandProps }, avatar, features: { hasLogout, hasManageAccount, hasUsername, }, kebabDropdownItems, dropdownItems, toolbarItems, ...rest }: KeycloakMastheadProps) => import("react/jsx-runtime").JSX.Element;
18
+ declare const KeycloakMasthead: ({ keycloak, brand: { src, alt, className, ...brandProps }, avatar, features: { hasLogout, hasManageAccount, hasUsername, }, kebabDropdownItems, dropdownItems, toolbarItems, ...rest }: KeycloakMastheadProps) => import("react/jsx-runtime").JSX.Element;
22
19
  export default KeycloakMasthead;
@@ -10,8 +10,8 @@ var __rest = (this && this.__rest) || function (s, e) {
10
10
  return t;
11
11
  };
12
12
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
- import { Avatar, Brand, DropdownItem, } from "@patternfly/react-core";
14
- import { PageHeader, PageHeaderTools, PageHeaderToolsGroup, PageHeaderToolsItem, } from "@patternfly/react-core/deprecated";
13
+ import { Avatar, DropdownItem, Masthead, MastheadBrand, MastheadContent, MastheadToggle, PageToggleButton, Toolbar, ToolbarContent, ToolbarItem, } from "@patternfly/react-core";
14
+ import { BarsIcon } from "@patternfly/react-icons";
15
15
  import { useTranslation } from "react-i18next";
16
16
  import { DefaultAvatar } from "../../ui-shared/masthead/DefaultAvatar";
17
17
  import { KeycloakDropdown } from "../../ui-shared/masthead/KeycloakDropdown";
@@ -29,7 +29,7 @@ function loggedInUserName(token, t) {
29
29
  }
30
30
  const KeycloakMasthead = (_a) => {
31
31
  var _b;
32
- var { keycloak } = _a, _c = _a.brand, { href: brandHref } = _c, brandProps = __rest(_c, ["href"]), { avatar, features: { hasLogout = true, hasManageAccount = true, hasUsername = true, } = {}, kebabDropdownItems, dropdownItems = [], toolbarItems } = _a, rest = __rest(_a, ["keycloak", "brand", "avatar", "features", "kebabDropdownItems", "dropdownItems", "toolbarItems"]);
32
+ var { keycloak } = _a, _c = _a.brand, { src, alt, className } = _c, brandProps = __rest(_c, ["src", "alt", "className"]), { avatar, features: { hasLogout = true, hasManageAccount = true, hasUsername = true, } = {}, kebabDropdownItems, dropdownItems = [], toolbarItems } = _a, rest = __rest(_a, ["keycloak", "brand", "avatar", "features", "kebabDropdownItems", "dropdownItems", "toolbarItems"]);
33
33
  const { t } = useTranslation();
34
34
  const extraItems = [];
35
35
  if (hasManageAccount) {
@@ -39,17 +39,17 @@ const KeycloakMasthead = (_a) => {
39
39
  extraItems.push(_jsx(DropdownItem, { onClick: () => keycloak.logout(), children: t("signOut") }, "signOut"));
40
40
  }
41
41
  const picture = (_b = keycloak.idTokenParsed) === null || _b === void 0 ? void 0 : _b.picture;
42
- return (_jsx(PageHeader, Object.assign({}, rest, { logo: _jsx(Brand, Object.assign({}, brandProps)), logoProps: { href: brandHref }, headerTools: _jsxs(PageHeaderTools, { children: [_jsxs(PageHeaderToolsGroup, { children: [_jsx(PageHeaderToolsItem, { visibility: {
43
- md: "hidden",
44
- }, children: _jsx(KeycloakDropdown, { "data-testid": "options-kebab", isKebab: true, dropDownItems: [
45
- ...(kebabDropdownItems || dropdownItems),
46
- extraItems,
47
- ] }) }), _jsx(PageHeaderToolsItem, { children: toolbarItems }), _jsx(PageHeaderToolsItem, { visibility: {
48
- default: "hidden",
49
- md: "visible",
50
- }, children: _jsx(KeycloakDropdown, { "data-testid": "options", dropDownItems: [...dropdownItems, extraItems], title: hasUsername
51
- ? loggedInUserName(keycloak.idTokenParsed, t)
52
- : undefined }) })] }), picture || (avatar === null || avatar === void 0 ? void 0 : avatar.src) ? (_jsx(Avatar, Object.assign({ src: picture, alt: t("avatar") }, avatar))) : (_jsx(DefaultAvatar, Object.assign({}, avatar)))] }) })));
42
+ return (_jsxs(Masthead, Object.assign({}, rest, { children: [_jsx(MastheadToggle, { children: _jsx(PageToggleButton, { variant: "plain", "aria-label": t("navigation"), children: _jsx(BarsIcon, {}) }) }), _jsx(MastheadBrand, Object.assign({}, brandProps, { children: _jsx("img", { src: src, alt: alt, className: className }) })), _jsx(MastheadContent, { children: _jsx(Toolbar, { children: _jsxs(ToolbarContent, { children: [toolbarItems === null || toolbarItems === void 0 ? void 0 : toolbarItems.map((item, index) => (_jsx(ToolbarItem, { align: { default: "alignRight" }, children: item }, index))), _jsx(ToolbarItem, { visibility: {
43
+ default: "hidden",
44
+ md: "visible",
45
+ }, children: _jsx(KeycloakDropdown, { "data-testid": "options", dropDownItems: [...dropdownItems, extraItems], title: hasUsername
46
+ ? loggedInUserName(keycloak.idTokenParsed, t)
47
+ : undefined }) }), _jsx(ToolbarItem, { align: { default: "alignLeft" }, visibility: {
48
+ md: "hidden",
49
+ }, children: _jsx(KeycloakDropdown, { "data-testid": "options-kebab", isKebab: true, dropDownItems: [
50
+ ...(kebabDropdownItems || dropdownItems),
51
+ extraItems,
52
+ ] }) }), _jsx(ToolbarItem, { variant: "overflow-menu", align: { default: "alignRight" }, className: "pf-v5-u-m-0-on-lg", children: picture || (avatar === null || avatar === void 0 ? void 0 : avatar.src) ? (_jsx(Avatar, Object.assign({ src: picture, alt: t("avatar") }, avatar))) : (_jsx(DefaultAvatar, Object.assign({}, avatar))) })] }) }) })] })));
53
53
  };
54
54
  export default KeycloakMasthead;
55
55
  //# sourceMappingURL=Masthead.js.map