From 6cd6cb866af2ec17357b13a51e9fad56af743446 Mon Sep 17 00:00:00 2001 From: Tiago Paiva Date: Wed, 11 Dec 2024 13:41:24 -0300 Subject: [PATCH] fix: Preserve Page number in URL at AuditLogs page (#4913) --- frontend/web/components/AuditLog.tsx | 14 ++++++++++++-- frontend/web/components/pages/AuditLogPage.tsx | 11 +++++++++++ 2 files changed, 23 insertions(+), 2 deletions(-) diff --git a/frontend/web/components/AuditLog.tsx b/frontend/web/components/AuditLog.tsx index d66651c7ec70..aa3009c2857c 100644 --- a/frontend/web/components/AuditLog.tsx +++ b/frontend/web/components/AuditLog.tsx @@ -21,6 +21,7 @@ type AuditLogType = { projectId: string pageSize: number onSearchChange?: (search: string) => void + onPageChange?: (page: number) => void searchPanel?: ReactNode onErrorChange?: (err: boolean) => void match: { @@ -33,11 +34,15 @@ type AuditLogType = { const widths = [210, 310, 150] const AuditLog: FC = (props) => { - const [page, setPage] = useState(1) + const [page, setPage] = useState(Utils.fromParam().page ?? 1) const { search, searchInput, setSearchInput } = useSearchThrottle( Utils.fromParam().search, () => { - setPage(1) + if (searchInput !== search) { + return setPage(1) + } + + setPage(Utils.fromParam().page) }, ) const { data: subscriptionMeta } = useGetSubscriptionMetadataQuery({ @@ -58,6 +63,11 @@ const AuditLog: FC = (props) => { //eslint-disable-next-line }, [search]) + useEffect(() => { + props.onPageChange?.(page) + //eslint-disable-next-line + }, [page]) + const hasHadResults = useRef(false) const { diff --git a/frontend/web/components/pages/AuditLogPage.tsx b/frontend/web/components/pages/AuditLogPage.tsx index 6b90de97f5cb..ffe36670f23a 100644 --- a/frontend/web/components/pages/AuditLogPage.tsx +++ b/frontend/web/components/pages/AuditLogPage.tsx @@ -29,6 +29,7 @@ const AuditLogPage: FC = (props) => { props.router.history.replace( `${document.location.pathname}?${Utils.toParam({ env: environment, + page: currentParams.page, search: currentParams.search, })}`, ) @@ -52,10 +53,20 @@ const AuditLogPage: FC = (props) => { props.router.history.replace( `${document.location.pathname}?${Utils.toParam({ env: environment, + page: Utils.fromParam().page, search, })}`, ) }} + onPageChange={(page: number) => { + props.router.history.replace( + `${document.location.pathname}?${Utils.toParam({ + env: environment, + page, + search: Utils.fromParam().search, + })}`, + ) + }} pageSize={10} environmentId={environment} projectId={projectId}