From 342e5ca08a0c40329caadeded848fc00a267afcc Mon Sep 17 00:00:00 2001 From: Ian Svoboda Date: Mon, 25 Nov 2024 16:25:33 -0500 Subject: [PATCH] Fix post_per_page and offset handling in preview --- .../components/LoopInnerBlocksRenderer.jsx | 23 ++++++++++++------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/src/blocks/looper/components/LoopInnerBlocksRenderer.jsx b/src/blocks/looper/components/LoopInnerBlocksRenderer.jsx index c1f662232..955101365 100644 --- a/src/blocks/looper/components/LoopInnerBlocksRenderer.jsx +++ b/src/blocks/looper/components/LoopInnerBlocksRenderer.jsx @@ -235,18 +235,25 @@ export function LoopInnerBlocksRenderer( props ) { const loopItemsContext = useMemo( () => { if ( hasResolvedData && Array.isArray( data ) ) { - let perPage = query?.posts_per_page - ? query?.posts_per_page - : 10; + let { posts_per_page: perPage = 10, offset = 0 } = query; - if ( '-1' === perPage?.toString() ) { + // Ensure the params are a valid integer for comparison. + perPage = parseInt( perPage, 10 ); + offset = parseInt( offset, 10 ); + + console.log( { perPage, offset } ); + + if ( perPage < 0 ) { perPage = data.length; } - const items = data.slice( 0, perPage ); + const items = data.slice( + offset > -1 ? offset : 0, + offset > -1 ? offset + perPage : perPage + ); return items.map( ( item, index ) => { - const { ID = null, id = null, type = 'post' } = item; + const { ID = null, id = null, post_type: postType = 'post' } = item; // Remove any disallowed or hidden keys for ( const itemKey in item ) { @@ -256,7 +263,7 @@ export function LoopInnerBlocksRenderer( props ) { } return { - postType: type, + postType, postId: id ? id : ID, 'generateblocks/loopItem': item, 'generateblocks/loopIndex': index + 1, // Preview doesn't support pagination so this index is correct. @@ -273,7 +280,7 @@ export function LoopInnerBlocksRenderer( props ) { }, 'generateblocks/loopIndex': 1, } ]; - }, [ data, hasResolvedData, query?.per_page ] ); + }, [ data, hasResolvedData, query?.posts_per_page, query?.offset ] ); if ( isResolvingData ) { return ( );