Skip to content

Commit

Permalink
Add pagination
Browse files Browse the repository at this point in the history
Signed-off-by: abbyhu2000 <[email protected]>
  • Loading branch information
abbyhu2000 committed Feb 1, 2024
1 parent 8ec8176 commit 0013c05
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ export interface DataGridTableProps {
isContextView?: boolean;
isLoading?: boolean;
storage: Storage;
showPagination?: boolean;
}

export const DataGridTable = ({
Expand All @@ -61,6 +62,7 @@ export const DataGridTable = ({
isContextView = false,
isLoading = false,
storage,
showPagination,
}: DataGridTableProps) => {
const { services } = useOpenSearchDashboards<DiscoverServices>();

Expand Down Expand Up @@ -161,6 +163,7 @@ export const DataGridTable = ({
onFilter={onFilter}
onClose={() => setInspectedHit(undefined)}
sampleSize={pageSizeLimit}
showPagination={showPagination}
/>
),
[
Expand All @@ -175,6 +178,7 @@ export const DataGridTable = ({
onAddColumn,
onFilter,
pageSizeLimit,
showPagination,
]
);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@ import {
EuiDataGridColumn,
EuiDataGridSorting,
EuiProgress,
EuiPagination,
EuiFlexGroup,
EuiFlexItem,
} from '@elastic/eui';
import { FormattedMessage } from '@osd/i18n/react';
import { TableHeader } from './table_header';
Expand All @@ -35,6 +38,7 @@ export interface DefaultDiscoverTableProps {
onFilter: DocViewFilterFn;
onClose: () => void;
sampleSize: number;
showPagination?: boolean;
}

export const LegacyDiscoverTable = ({
Expand All @@ -50,8 +54,17 @@ export const LegacyDiscoverTable = ({
onFilter,
onClose,
sampleSize,
showPagination,
}: DefaultDiscoverTableProps) => {
const pageSize = 50;
const [renderedRowCount, setRenderedRowCount] = useState(50); // Start with 50 rows
const [displayedRows, setDisplayedRows] = useState(
showPagination ? rows.slice(0, pageSize) : rows.slice(0, renderedRowCount)
);
const [currentRowCounts, setCurrentRowCounts] = useState({
startRow: 0,
endRow: pageSize,
});
const observerRef = useRef<IntersectionObserver | null>(null);
const sentinelRef = useRef<HTMLDivElement | null>(null);

Expand Down Expand Up @@ -81,9 +94,48 @@ export const LegacyDiscoverTable = ({
};
}, []);

const [activePage, setActivePage] = useState(0);
const PAGE_COUNT = Math.ceil(rows.length / pageSize);

const goToPage = (pageNumber: number) => {
const startRow = pageNumber * pageSize;
const endRow =
rows.length < pageNumber * pageSize + pageSize
? rows.length
: pageNumber * pageSize + pageSize;
setCurrentRowCounts({
startRow,
endRow,
});
setDisplayedRows(rows.slice(startRow, endRow));
setActivePage(pageNumber);
};

return (
indexPattern && (
<>
{showPagination ? (
<EuiFlexGroup>
<EuiFlexItem grow={false}>
<EuiPagination
pageCount={PAGE_COUNT}
activePage={activePage}
onPageClick={(currentPage) => goToPage(currentPage)}
/>
</EuiFlexItem>
<EuiFlexItem>
<FormattedMessage
id="discover.docTable.pagerControl.pagesCountLabel"
defaultMessage="{startItem}&ndash;{endItem} of {totalItems}"
values={{
startItem: currentRowCounts.startRow,
endItem: currentRowCounts.endRow,
totalItems: rows.length,
}}
/>
</EuiFlexItem>
</EuiFlexGroup>
) : null}
<table data-test-subj="docTable" className="osd-table table">
<thead>
<TableHeader
Expand All @@ -99,7 +151,7 @@ export const LegacyDiscoverTable = ({
/>
</thead>
<tbody>
{rows.slice(0, renderedRowCount).map((row: OpenSearchSearchHit, index: number) => {
{displayedRows.map((row: OpenSearchSearchHit, index: number) => {
return (
<TableRow
key={index}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ interface SearchEmbeddableProps {
}
export interface DiscoverEmbeddableProps extends DataGridTableProps {
totalHitCount: number;
showPagination: boolean;
}

export const DataGridTableMemoized = React.memo((props: DataGridTableProps) => (
Expand All @@ -45,6 +46,7 @@ export function SearchEmbeddableComponent({ searchProps }: SearchEmbeddableProps
title: searchProps.title,
description: searchProps.description,
storage,
showPagination: true,
} as DiscoverEmbeddableProps;

return (
Expand Down

0 comments on commit 0013c05

Please sign in to comment.