Stable tag: 0.11.0
Requires at least: 6.4
Tested up to: 6.9
Requires PHP: 7.4
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Tags: zones, post order, post list, posts, order, zonination, content curation, curation, content management
Contributors: batmoo, automattic, wpcomvip, pkevan, matthumphreys, potatomaster, jblz, nickdaugherty, betzster, garyj
Content curation made easy! Create "zones" then add and order your content!
This plugin is designed to help you curate your content. It lets you assign and order stories within zones that you create, edit, and delete, and display those groupings of related stories on your site.
This plugin was originally built by Mohammad Jangda in conjunction with William Davis and the Bangor Daily News.
- Add, edit, and delete zones.
- Add and remove posts (or any custom post type) to or from zones.
- Order posts in any given zone.
- Limit capabilities on who can add, edit, and delete zones vs add content to zones.
- Locking mechanism, so only one user can edit a zone at a time (to avoid conflicts).
- Idle control, so people can't keep the zone locked.
- Unzip contents and upload to the
/wp-content/plugins/directory - Activate the plugin through the 'Plugins' menu in WordPress
- Go to Dashboard > Zones to create and manage your zones, and easily search for and add existing posts.
- Use the plugin's handy API functions to add zones to your theme that retrieve and display your content. Or, for those who are a bit code-averse, go to Appearance-Widgets and add Zone Posts widgets to display your zone posts in your sidebar or footer. The widget will pull the posts from the chosen zone.
You can work with a zone's posts either as a WP_Query object or as a plain array.
WP_Query
$zone_query = z_get_zone_query( 'homepage' );
if ( $zone_query->have_posts() ) :
while ( $zone_query->have_posts() ) : $zone_query->the_post();
echo '<li>' . esc_html( get_the_title() ) . '</li>';
endwhile;
wp_reset_postdata();
endif;Posts Array
$zone_posts = z_get_posts_in_zone( 'homepage' );
foreach ( $zone_posts as $zone_post ) :
echo '<li>' . esc_html( get_the_title( $zone_post->ID ) ) . '</li>';
endforeach;For the full template-tag reference, see the theme developer guide.
Audience-targeted documentation lives in the GitHub repository:
- Theme developer guide — using zones in your theme.
- Hooks reference — every filter and action the plugin exposes.
- REST API — endpoints under the
zoninator/v1namespace, for headless integrations. - Contributing — local setup, tests, and PR conventions.
- Security — responsible disclosure.
You can use a filter:
add_filter( 'zoninator_zone_max_lock_period', 'z_disable_zoninator_locks' );Filter the following and change according to your needs:
- Number of seconds a lock is valid for, default
30:zoninator_zone_lock_period - Max idle time in seconds:
zoninator_zone_max_lock_period
Not by default since version 0.11.0. The GET /wp-json/zoninator/v1/zones endpoint now requires an authenticated user. If your integration relied on anonymous access, you can restore the previous behaviour with the zoninator_rest_get_zones_permissions_check filter:
add_filter( 'zoninator_rest_get_zones_permissions_check', '__return_true' );See the REST API documentation for the full endpoint reference.
Yes. Call Zoninator()->register_zone_post_type( 'your_post_type' ) after init to add zone support to a custom post type.
The GET /wp-json/zoninator/v1/zones REST endpoint now requires an authenticated user. If your site depends on anonymous access, opt back in with the zoninator_rest_get_zones_permissions_check filter. Three security fixes are included — review the changelog before upgrading.
Please visit the changelog.



