[!IMPORTANT] This plugin is NOT compatible with Gutenberg on WordPress 5.x. Consider using Classic Editor Plugin.
[!IMPORTANT] Mutation events will no longer be supported in Google Chrome and Edge in July 2024 (Google Chrome on July 23, 2024, and Microsoft Edge the week of July 25, 2024). As a result, WP Tag Order versions 3.6.0 or less will not work with Chrome v127 and later, which will be released on July 23, 2024.
You have to update to v3.7.0 or later.
If you still need PHP7 support, see Troubleshooting below.
See Chrome for Developers Blog for more details.
wp-content/plugins
directory.
cd /path-to-your/wp-content/plugins
git clone git@github.com:sectsect/wp-tag-order.git
Plugins
menu in WordPress.Settings
-> WP Tag Order
page to select which taxonomies to enable ordering for.Settings
-> WP Tag Order
page and click 'Apply' under the Advanced Settings.Function | Description |
---|---|
get_the_tags_ordered() |
Based on get_the_tags() - Codex |
get_the_terms_ordered() |
Based on get_the_terms() - Codex |
get_the_tag_list_ordered() |
Based on get_the_tag_list() - Codex |
get_the_term_list_ordered() |
Based on get_the_term_list() - Codex |
the_tags_ordered() |
Based on the_tags() - Codex |
the_terms_ordered() |
Based on the_terms() - Codex |
get_the_tags_ordered()
<?php
$terms = get_the_tags_ordered();
if ( $terms && ! is_wp_error( $terms ) ) :
?>
<ul>
<?php foreach ( $terms as $term ) : ?>
<li>
<a href="https://github.com/sectsect/wp-tag-order/blob/master/<?php echo get_term_link( $term->slug, 'post_tag' ); ?>">
<?php echo $term->name; ?>
</a>
</li>
<?php endforeach; ?>
</ul>
<?php endif; ?>
get_the_terms_ordered()
<?php
$terms = get_the_terms_ordered( $post->ID, 'post_tag' );
if ( $terms && ! is_wp_error( $terms ) ) :
?>
<ul>
<?php foreach ( $terms as $term ) : ?>
<li>
<a href="https://github.com/sectsect/wp-tag-order/blob/master/<?php echo get_term_link( $term->slug, 'post_tag' ); ?>">
<?php echo $term->name; ?>
</a>
</li>
<?php endforeach; ?>
</ul>
<?php endif; ?>
get_the_tag_list_ordered()
<?php echo get_the_tag_list_ordered(); ?>
get_the_term_list_ordered()
<?php echo get_the_term_list_ordered( $post->ID, 'post_tag' ); ?>
the_tags_ordered()
<?php the_tags_ordered(); ?>
the_terms_ordered()
<?php the_terms_ordered( $post->ID, 'post_tag' ); ?>
The plugin provides a Tag_Updater
class for developers to programmatically manage tag order:
$tag_updater = new \WP_Tag_Order\Tag_Updater();
try {
// Update tag order using an array or comma-separated string
$result = $tag_updater->update_tag_order(
get_the_ID(), // Post ID
'post_tag', // Taxonomy that enabled in plugin settings
[1, 2, 3] // Tag IDs in desired order
);
} catch ( \InvalidArgumentException $e ) {
// Error handling
error_log( $e->getMessage() );
}
This class allows flexible tag order updates directly from your theme or custom plugin code, supporting both array and string inputs with robust validation.
update_tag_order()
returns: int|bool
int
: Meta ID if the tag order meta key didn't previously existtrue
: Successful update of existing metafalse
: Update failed or the new tag order is identical to the existing orderThe WP Tag Order plugin provides two REST API endpoints for managing tag order:
/wp-json/wp-tag-order/v1/tags/order/{post_id}
GET
post_id
(required): The ID of the posttaxonomy
(optional): Taxonomy name (defaults to 'post_tag')GET /wp-json/wp-tag-order/v1/tags/order/123
/wp-json/wp-tag-order/v1/tags/order/{post_id}
PUT
or PATCH
post_id
(required): The ID of the posttaxonomy
(required): Taxonomy nametags
(required): Comma-separated list of tag IDs in desired orderPUT /wp-json/wp-tag-order/v1/tags/order/123
{
"taxonomy": "post_tag",
"tags": "5,3,1,4,2"
}
{
"success": true,
"code": "tags_order_updated",
"message": "Tag order updated successfully.",
"data": {
"status": 200,
"post_id": 123,
"taxonomy": "post_tag",
"tags": [
5,
3,
1,
4,
2
]
}
}
The ordered tag data is serialized and stored in the wp_postmeta
table under keys like wp-tag-order-{taxonomy}
.
meta_id | post_id | meta_key | meta_value |
---|---|---|---|
19 | 7 | wp-tag-order-post_tag | s:91:"a:7:{i:0;s:1:"7";i:1;s:1:"5";i:2;s:2:"10";i:3;s:1:"4";i:4;s:1:"6";i:5;s:1:"8";i:6;s:1:"9";}"; |
This Plugin does not hosting on the wordpress.org repo in order to prevent a flood of support requests from wide audience. Your feedback is welcome.
I have a branch php7 to support PHP 7 and End-of-Life for JaveScript Mutation events.
The branch will not be maintained anymore, so I recommend you migrate to PHP 8.
See CHANGELOG file.
See LICENSE file.
✌️
A little project by @sectsect