-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Get the page count as derived data #55316
Conversation
@@ -233,9 +233,6 @@ export const getEntityRecords = | |||
const response = await apiFetch( { path, parse: false } ); | |||
records = Object.values( await response.json() ); | |||
meta = { | |||
totalPages: parseInt( | |||
response.headers.get( 'X-WP-TotalPages' ) | |||
), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder if there's a way to store this in the reducer with the "perPage" as a sub key in order to retrieve the right value in the selector instead of computing it.
I wonder which is best
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not super confident that I could make that change.. I checked about the sub keys, but haven't touched that part of the code at all before.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I can make the change myself, I'm just wondering which is better. Should we rely on the server side value or the computed one.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a simple calculation and it seems core does that too:
$max_pages = ceil( $total_posts / (int) $posts_query->query_vars['posts_per_page'] );
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, let's keep it that way for now then, we can always change anytime :)
Size Change: +31 B (0%) Total Size: 1.65 MB
ℹ️ View Unchanged
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍
Flaky tests detected in f496132. 🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/6498431702
|
if ( query.per_page === -1 ) return 1; | ||
const totalItems = getQueriedTotalItems( queriedState, query ); | ||
if ( ! totalItems ) return totalItems; | ||
return Math.ceil( totalItems / query.per_page ); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This can result in NaN
; the query.per_page
can be undefined
when the request relies on the default per_page
by REST API.
We can try using default 10
as a fallback, but that would be incorrect for some entities that don't support pagination or if the project changes default per_page
for endpoints.
I was debugging the useEntityRecords
hook triggering unstable references warning (NaN !== NaN
), which led me here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Good catch! I guess if the per_page
is not provided, we can fallback to the header of the response, since it should update properly with other changes of the query. The problem was with the perPage argument not being part of the stable key. I'll open a PR in a bit.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, @ntsekouras!
What?
Recently there was an update to core-data package to include the total number of records and pages per query.
There is a bug though in getting the total pages of a query, because internally in state we keep the queries with a stable key, which doesn't include the
perPage
argument. This makes sense in practice, but the stored value for total pages has the value of the last request.I kept the same APIs, but I'm calculating the total pages based on the total number of records.
Testing Instructions