@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.
- package/KcAccountUiLoader.d.ts +1 -0
- package/KcAccountUiLoader.js +2 -1
- package/KcAccountUiLoader.js.map +1 -1
- package/README.md +19 -19
- package/account-security/AccountRow.js +5 -4
- package/account-security/AccountRow.js.map +1 -1
- package/account-security/DeviceActivity.js +5 -4
- package/account-security/DeviceActivity.js.map +1 -1
- package/account-security/LinkedAccounts.js +24 -9
- package/account-security/LinkedAccounts.js.map +1 -1
- package/account-security/LinkedAccountsToolbar.d.ts +12 -0
- package/account-security/LinkedAccountsToolbar.js +24 -0
- package/account-security/LinkedAccountsToolbar.js.map +1 -0
- package/account-security/SigningIn.js +1 -1
- package/account-security/SigningIn.js.map +1 -1
- package/api/methods.d.ts +7 -1
- package/api/methods.js +9 -2
- package/api/methods.js.map +1 -1
- package/api/parse-links.js +3 -3
- package/api/parse-links.js.map +1 -1
- package/api/parse-response.d.ts +2 -0
- package/api/parse-response.js +11 -15
- package/api/parse-response.js.map +1 -1
- package/api/request.js +1 -1
- package/api/request.js.map +1 -1
- package/api.js +1 -7
- package/api.js.map +1 -1
- package/applications/Applications.js +5 -4
- package/applications/Applications.js.map +1 -1
- package/environment.d.ts +1 -0
- package/environment.js.map +1 -1
- package/messages/messages_ca.properties +105 -12
- package/messages/messages_de.properties +23 -1
- package/messages/messages_en.properties +16 -1
- package/messages/messages_es.properties +1 -1
- package/messages/messages_fr.properties +64 -19
- package/messages/messages_it.properties +3 -0
- package/messages/messages_ka.properties +15 -0
- package/messages/messages_nl.properties +2 -0
- package/organizations/Organizations.d.ts +2 -0
- package/organizations/Organizations.js +19 -0
- package/organizations/Organizations.js.map +1 -0
- package/package.json +89 -29
- package/personal-info/PersonalInfo.js +11 -9
- package/personal-info/PersonalInfo.js.map +1 -1
- package/public/content.d.ts +4 -0
- package/public/content.js +5 -0
- package/public/content.js.map +1 -1
- package/resources/EditTheResource.js +4 -3
- package/resources/EditTheResource.js.map +1 -1
- package/resources/PermissionRequest.js +4 -3
- package/resources/PermissionRequest.js.map +1 -1
- package/resources/ResourcesTab.js +4 -3
- package/resources/ResourcesTab.js.map +1 -1
- package/resources/ShareTheResource.js +4 -3
- package/resources/ShareTheResource.js.map +1 -1
- package/root/Header.js +1 -1
- package/root/Header.js.map +1 -1
- package/root/PageNav.js +1 -1
- package/root/PageNav.js.map +1 -1
- package/routes.d.ts +1 -0
- package/routes.js +6 -0
- package/routes.js.map +1 -1
- package/src/KcAccountUiLoader.tsx +2 -0
- package/src/account-security/AccountRow.tsx +6 -8
- package/src/account-security/DeviceActivity.tsx +10 -9
- package/src/account-security/LinkedAccounts.tsx +107 -30
- package/src/account-security/LinkedAccountsToolbar.tsx +88 -0
- package/src/account-security/SigningIn.tsx +1 -1
- package/src/api/methods.ts +22 -2
- package/src/api/parse-links.ts +3 -3
- package/src/api/parse-response.ts +22 -23
- package/src/api/request.ts +1 -1
- package/src/api.ts +1 -7
- package/src/applications/Applications.tsx +19 -11
- package/src/environment.ts +1 -0
- package/src/organizations/Organizations.tsx +48 -0
- package/src/personal-info/PersonalInfo.tsx +10 -8
- package/src/public/content.ts +5 -0
- package/src/resources/EditTheResource.tsx +8 -7
- package/src/resources/PermissionRequest.tsx +5 -3
- package/src/resources/ResourcesTab.tsx +8 -7
- package/src/resources/ShareTheResource.tsx +9 -8
- package/src/root/Header.tsx +0 -1
- package/src/root/PageNav.tsx +1 -1
- package/src/routes.tsx +7 -0
- package/src/ui-shared/alerts/AlertPanel.tsx +43 -0
- package/src/ui-shared/alerts/Alerts.tsx +48 -52
- package/src/ui-shared/context/environment.ts +1 -1
- package/src/ui-shared/controls/KeycloakSpinner.tsx +12 -0
- package/src/ui-shared/controls/OrganizationTable.tsx +122 -0
- package/src/ui-shared/controls/select-control/SingleSelectControl.tsx +3 -1
- package/src/ui-shared/controls/select-control/TypeaheadSelectControl.tsx +5 -3
- package/src/ui-shared/controls/table/KeycloakDataTable.tsx +597 -0
- package/src/ui-shared/controls/table/ListEmptyState.tsx +86 -0
- package/src/ui-shared/controls/table/PaginatingTableToolbar.tsx +106 -0
- package/src/ui-shared/controls/table/TableToolbar.tsx +92 -0
- package/src/ui-shared/main.ts +35 -1
- package/src/ui-shared/masthead/Masthead.tsx +64 -48
- package/src/ui-shared/select/SingleSelect.tsx +2 -0
- package/src/ui-shared/select/TypeaheadSelect.tsx +2 -0
- package/src/ui-shared/user-profile/LocaleSelector.tsx +1 -1
- package/src/ui-shared/user-profile/UserProfileFields.tsx +18 -21
- package/src/ui-shared/user-profile/UserProfileGroup.tsx +3 -2
- package/src/ui-shared/user-profile/utils.ts +12 -6
- package/src/ui-shared/utils/ErrorBoundary.tsx +77 -0
- package/src/ui-shared/utils/darkMode.ts +19 -0
- package/src/ui-shared/utils/errors.ts +55 -0
- package/src/ui-shared/utils/generateId.ts +1 -0
- package/src/ui-shared/utils/useFetch.ts +44 -0
- package/src/ui-shared/utils/useSetTimeout.ts +40 -0
- package/src/utils/useAccountAlerts.ts +28 -0
- package/src/utils/usePromise.ts +8 -3
- package/src/zKcContextLike.ts +1 -0
- package/ui-shared/alerts/AlertPanel.d.ts +6 -0
- package/ui-shared/alerts/AlertPanel.js +6 -0
- package/ui-shared/alerts/AlertPanel.js.map +1 -0
- package/ui-shared/alerts/Alerts.d.ts +2 -3
- package/ui-shared/alerts/Alerts.js +32 -22
- package/ui-shared/alerts/Alerts.js.map +1 -1
- package/ui-shared/context/environment.js +1 -1
- package/ui-shared/context/environment.js.map +1 -1
- package/ui-shared/controls/KeycloakSpinner.d.ts +1 -0
- package/ui-shared/controls/KeycloakSpinner.js +8 -0
- package/ui-shared/controls/KeycloakSpinner.js.map +1 -0
- package/ui-shared/controls/OrganizationTable.d.ts +16 -0
- package/ui-shared/controls/OrganizationTable.js +45 -0
- package/ui-shared/controls/OrganizationTable.js.map +1 -0
- package/ui-shared/controls/select-control/SingleSelectControl.js +3 -1
- package/ui-shared/controls/select-control/SingleSelectControl.js.map +1 -1
- package/ui-shared/controls/select-control/TypeaheadSelectControl.js +5 -3
- package/ui-shared/controls/select-control/TypeaheadSelectControl.js.map +1 -1
- package/ui-shared/controls/table/KeycloakDataTable.d.ts +64 -0
- package/ui-shared/controls/table/KeycloakDataTable.js +279 -0
- package/ui-shared/controls/table/KeycloakDataTable.js.map +1 -0
- package/ui-shared/controls/table/ListEmptyState.d.ts +20 -0
- package/ui-shared/controls/table/ListEmptyState.js +11 -0
- package/ui-shared/controls/table/ListEmptyState.js.map +1 -0
- package/ui-shared/controls/table/PaginatingTableToolbar.d.ts +21 -0
- package/ui-shared/controls/table/PaginatingTableToolbar.js +27 -0
- package/ui-shared/controls/table/PaginatingTableToolbar.js.map +1 -0
- package/ui-shared/controls/table/TableToolbar.d.ts +12 -0
- package/ui-shared/controls/table/TableToolbar.js +30 -0
- package/ui-shared/controls/table/TableToolbar.js.map +1 -0
- package/ui-shared/main.d.ts +15 -1
- package/ui-shared/main.js +13 -1
- package/ui-shared/main.js.map +1 -1
- package/ui-shared/masthead/Masthead.d.ts +4 -7
- package/ui-shared/masthead/Masthead.js +14 -14
- package/ui-shared/masthead/Masthead.js.map +1 -1
- package/ui-shared/select/SingleSelect.d.ts +1 -1
- package/ui-shared/select/SingleSelect.js +2 -2
- package/ui-shared/select/SingleSelect.js.map +1 -1
- package/ui-shared/select/TypeaheadSelect.d.ts +1 -1
- package/ui-shared/select/TypeaheadSelect.js +2 -2
- package/ui-shared/select/TypeaheadSelect.js.map +1 -1
- package/ui-shared/user-profile/LocaleSelector.js +1 -1
- package/ui-shared/user-profile/LocaleSelector.js.map +1 -1
- package/ui-shared/user-profile/UserProfileFields.d.ts +2 -4
- package/ui-shared/user-profile/UserProfileFields.js +0 -18
- package/ui-shared/user-profile/UserProfileFields.js.map +1 -1
- package/ui-shared/user-profile/UserProfileGroup.js.map +1 -1
- package/ui-shared/user-profile/utils.js +2 -2
- package/ui-shared/user-profile/utils.js.map +1 -1
- package/ui-shared/utils/ErrorBoundary.d.ts +26 -0
- package/ui-shared/utils/ErrorBoundary.js +29 -0
- package/ui-shared/utils/ErrorBoundary.js.map +1 -0
- package/ui-shared/utils/darkMode.d.ts +1 -0
- package/ui-shared/utils/darkMode.js +16 -0
- package/ui-shared/utils/darkMode.js.map +1 -0
- package/ui-shared/utils/errors.d.ts +4 -0
- package/ui-shared/utils/errors.js +42 -0
- package/ui-shared/utils/errors.js.map +1 -0
- package/ui-shared/utils/generateId.d.ts +1 -0
- package/ui-shared/utils/generateId.js +2 -0
- package/ui-shared/utils/generateId.js.map +1 -0
- package/ui-shared/utils/useFetch.d.ts +17 -0
- package/ui-shared/utils/useFetch.js +38 -0
- package/ui-shared/utils/useFetch.js.map +1 -0
- package/ui-shared/utils/useSetTimeout.d.ts +1 -0
- package/ui-shared/utils/useSetTimeout.js +32 -0
- package/ui-shared/utils/useSetTimeout.js.map +1 -0
- package/utils/useAccountAlerts.d.ts +4 -0
- package/utils/useAccountAlerts.js +19 -0
- package/utils/useAccountAlerts.js.map +1 -0
- package/utils/usePromise.js +7 -3
- package/utils/usePromise.js.map +1 -1
- package/zKcContextLike.js +1 -0
- package/zKcContextLike.js.map +1 -1
- package/src/utils/isRecord.ts +0 -2
- package/utils/isRecord.d.ts +0 -1
- package/utils/isRecord.js +0 -2
- 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"}
|
package/ui-shared/main.d.ts
CHANGED
|
@@ -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
|
package/ui-shared/main.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/ui-shared/main.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
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,
|
|
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 =
|
|
6
|
-
|
|
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: {
|
|
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,
|
|
14
|
-
import {
|
|
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, {
|
|
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 (
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
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
|