2020-10-07 15:47:03 +00:00
|
|
|
import {
|
|
|
|
Pagination,
|
|
|
|
ToggleTemplateProps,
|
|
|
|
ToolbarItem,
|
|
|
|
} from "@patternfly/react-core";
|
2023-01-20 14:28:32 +00:00
|
|
|
import { PropsWithChildren, ReactNode } from "react";
|
2023-03-13 06:46:10 +00:00
|
|
|
import { useTranslation } from "react-i18next";
|
2023-01-20 14:28:32 +00:00
|
|
|
|
2020-10-07 15:47:03 +00:00
|
|
|
import { TableToolbar } from "./TableToolbar";
|
|
|
|
|
2023-03-09 13:50:11 +00:00
|
|
|
type KeycloakPaginationProps = {
|
|
|
|
id?: string;
|
2020-10-07 15:47:03 +00:00
|
|
|
count: number;
|
|
|
|
first: number;
|
|
|
|
max: number;
|
|
|
|
onNextClick: (page: number) => void;
|
|
|
|
onPreviousClick: (page: number) => void;
|
|
|
|
onPerPageSelect: (max: number, first: number) => void;
|
2023-03-09 13:50:11 +00:00
|
|
|
variant?: "top" | "bottom";
|
|
|
|
};
|
|
|
|
|
|
|
|
type TableToolbarProps = KeycloakPaginationProps & {
|
2021-06-15 11:12:32 +00:00
|
|
|
searchTypeComponent?: ReactNode;
|
|
|
|
toolbarItem?: ReactNode;
|
|
|
|
subToolbar?: ReactNode;
|
2020-10-07 15:47:03 +00:00
|
|
|
inputGroupName?: string;
|
|
|
|
inputGroupPlaceholder?: string;
|
2021-03-22 08:14:24 +00:00
|
|
|
inputGroupOnEnter?: (value: string) => void;
|
2020-10-07 15:47:03 +00:00
|
|
|
};
|
|
|
|
|
2023-03-09 13:50:11 +00:00
|
|
|
const KeycloakPagination = ({
|
|
|
|
id,
|
|
|
|
variant = "top",
|
2020-10-07 15:47:03 +00:00
|
|
|
count,
|
|
|
|
first,
|
|
|
|
max,
|
|
|
|
onNextClick,
|
|
|
|
onPreviousClick,
|
|
|
|
onPerPageSelect,
|
2023-03-09 13:50:11 +00:00
|
|
|
}: KeycloakPaginationProps) => {
|
2023-03-13 06:46:10 +00:00
|
|
|
const { t } = useTranslation("user-federation");
|
2021-02-16 08:39:26 +00:00
|
|
|
const page = Math.round(first / max);
|
2023-03-09 13:50:11 +00:00
|
|
|
return (
|
2020-10-07 15:47:03 +00:00
|
|
|
<Pagination
|
2023-03-09 13:50:11 +00:00
|
|
|
widgetId={id}
|
2023-03-13 06:46:10 +00:00
|
|
|
titles={{
|
|
|
|
paginationTitle: `${t("pagination")} ${variant} `,
|
|
|
|
}}
|
2020-10-07 15:47:03 +00:00
|
|
|
isCompact
|
|
|
|
toggleTemplate={({ firstIndex, lastIndex }: ToggleTemplateProps) => (
|
|
|
|
<b>
|
2021-06-16 11:35:03 +00:00
|
|
|
{firstIndex} - {lastIndex}
|
2020-10-07 15:47:03 +00:00
|
|
|
</b>
|
|
|
|
)}
|
2021-06-16 11:35:03 +00:00
|
|
|
itemCount={count + page * max}
|
2020-10-07 15:47:03 +00:00
|
|
|
page={page + 1}
|
|
|
|
perPage={max}
|
|
|
|
onNextClick={(_, p) => onNextClick((p - 1) * max)}
|
|
|
|
onPreviousClick={(_, p) => onPreviousClick((p - 1) * max)}
|
2021-02-16 08:39:26 +00:00
|
|
|
onPerPageSelect={(_, m, f) => onPerPageSelect(f - 1, m)}
|
2020-10-07 15:47:03 +00:00
|
|
|
variant={variant}
|
|
|
|
/>
|
|
|
|
);
|
2023-03-09 13:50:11 +00:00
|
|
|
};
|
2020-10-07 15:47:03 +00:00
|
|
|
|
2023-03-09 13:50:11 +00:00
|
|
|
export const PaginatingTableToolbar = ({
|
|
|
|
count,
|
|
|
|
searchTypeComponent,
|
|
|
|
toolbarItem,
|
|
|
|
subToolbar,
|
|
|
|
children,
|
|
|
|
inputGroupName,
|
|
|
|
inputGroupPlaceholder,
|
|
|
|
inputGroupOnEnter,
|
|
|
|
...rest
|
|
|
|
}: PropsWithChildren<TableToolbarProps>) => {
|
2020-10-07 15:47:03 +00:00
|
|
|
return (
|
|
|
|
<TableToolbar
|
2021-02-23 13:36:37 +00:00
|
|
|
searchTypeComponent={searchTypeComponent}
|
2020-10-07 15:47:03 +00:00
|
|
|
toolbarItem={
|
|
|
|
<>
|
|
|
|
{toolbarItem}
|
2023-01-16 12:09:27 +00:00
|
|
|
<ToolbarItem variant="pagination">
|
2023-03-09 13:50:11 +00:00
|
|
|
<KeycloakPagination count={count} {...rest} />
|
2023-01-16 12:09:27 +00:00
|
|
|
</ToolbarItem>
|
2020-10-07 15:47:03 +00:00
|
|
|
</>
|
|
|
|
}
|
2021-06-15 11:12:32 +00:00
|
|
|
subToolbar={subToolbar}
|
2021-03-31 08:48:14 +00:00
|
|
|
toolbarItemFooter={
|
2023-01-16 12:09:27 +00:00
|
|
|
count !== 0 ? (
|
|
|
|
<ToolbarItem>
|
2023-03-09 13:50:11 +00:00
|
|
|
<KeycloakPagination count={count} variant="bottom" {...rest} />
|
2023-01-16 12:09:27 +00:00
|
|
|
</ToolbarItem>
|
|
|
|
) : null
|
2021-03-31 08:48:14 +00:00
|
|
|
}
|
2020-10-07 15:47:03 +00:00
|
|
|
inputGroupName={inputGroupName}
|
|
|
|
inputGroupPlaceholder={inputGroupPlaceholder}
|
2021-03-22 08:14:24 +00:00
|
|
|
inputGroupOnEnter={inputGroupOnEnter}
|
2020-10-07 15:47:03 +00:00
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</TableToolbar>
|
|
|
|
);
|
|
|
|
};
|