require_once( dirname( __FILE__ ) . '/admin.php' );
if ( ! $taxnow )
- wp_die( __( 'Invalid taxonomy' ) );
+ wp_die( __( 'Invalid taxonomy.' ) );
$tax = get_taxonomy( $taxnow );
if ( ! $tax )
- wp_die( __( 'Invalid taxonomy' ) );
+ wp_die( __( 'Invalid taxonomy.' ) );
-if ( ! current_user_can( $tax->cap->manage_terms ) )
- wp_die( __( 'Cheatin’ uh?' ) );
+if ( ! in_array( $tax->name, get_taxonomies( array( 'show_ui' => true ) ) ) ) {
+ wp_die( __( 'Sorry, you are not allowed to manage these items.' ) );
+}
+
+if ( ! current_user_can( $tax->cap->manage_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to manage these items.' ) . '</p>',
+ 403
+ );
+}
+
+/**
+ * $post_type is set when the WP_Terms_List_Table instance is created
+ *
+ * @global string $post_type
+ */
+global $post_type;
$wp_list_table = _get_list_table('WP_Terms_List_Table');
$pagenum = $wp_list_table->get_pagenum();
if ( 'post' != $post_type ) {
$parent_file = ( 'attachment' == $post_type ) ? 'upload.php' : "edit.php?post_type=$post_type";
$submenu_file = "edit-tags.php?taxonomy=$taxonomy&post_type=$post_type";
-} else if ( 'link_category' == $tax->name ) {
+} elseif ( 'link_category' == $tax->name ) {
$parent_file = 'link-manager.php';
$submenu_file = 'edit-tags.php?taxonomy=link_category';
} else {
$submenu_file = "edit-tags.php?taxonomy=$taxonomy";
}
-add_screen_option( 'per_page', array( 'label' => $title, 'default' => 20, 'option' => 'edit_' . $tax->name . '_per_page' ) );
+add_screen_option( 'per_page', array( 'default' => 20, 'option' => 'edit_' . $tax->name . '_per_page' ) );
+
+get_current_screen()->set_screen_reader_content( array(
+ 'heading_pagination' => $tax->labels->items_list_navigation,
+ 'heading_list' => $tax->labels->items_list,
+) );
+
+$location = false;
+$referer = wp_get_referer();
switch ( $wp_list_table->current_action() ) {
check_admin_referer( 'add-tag', '_wpnonce_add-tag' );
- if ( !current_user_can( $tax->cap->edit_terms ) )
- wp_die( __( 'Cheatin’ uh?' ) );
+ if ( ! current_user_can( $tax->cap->edit_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to add this item.' ) . '</p>',
+ 403
+ );
+ }
$ret = wp_insert_term( $_POST['tag-name'], $taxonomy, $_POST );
$location = 'edit-tags.php?taxonomy=' . $taxonomy;
if ( 'post' != $post_type )
$location .= '&post_type=' . $post_type;
- if ( $referer = wp_get_original_referer() ) {
- if ( false !== strpos( $referer, 'edit-tags.php' ) )
- $location = $referer;
+ if ( $referer && false !== strpos( $referer, 'edit-tags.php' ) ) {
+ $location = $referer;
}
if ( $ret && !is_wp_error( $ret ) )
$location = add_query_arg( 'message', 1, $location );
else
- $location = add_query_arg( 'message', 4, $location );
- wp_redirect( $location );
- exit;
-break;
+ $location = add_query_arg( array( 'error' => true, 'message' => 4 ), $location );
+
+ break;
case 'delete':
$location = 'edit-tags.php?taxonomy=' . $taxonomy;
if ( 'post' != $post_type )
$location .= '&post_type=' . $post_type;
- if ( $referer = wp_get_referer() ) {
- if ( false !== strpos( $referer, 'edit-tags.php' ) )
- $location = $referer;
+
+ if ( $referer && false !== strpos( $referer, 'edit-tags.php' ) ) {
+ $location = $referer;
}
- if ( !isset( $_REQUEST['tag_ID'] ) ) {
- wp_redirect( $location );
- exit;
+ if ( ! isset( $_REQUEST['tag_ID'] ) ) {
+ break;
}
$tag_ID = (int) $_REQUEST['tag_ID'];
check_admin_referer( 'delete-tag_' . $tag_ID );
- if ( !current_user_can( $tax->cap->delete_terms ) )
- wp_die( __( 'Cheatin’ uh?' ) );
+ if ( ! current_user_can( $tax->cap->delete_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to delete this item.' ) . '</p>',
+ 403
+ );
+ }
wp_delete_term( $tag_ID, $taxonomy );
$location = add_query_arg( 'message', 2, $location );
- wp_redirect( $location );
- exit;
-break;
+ break;
case 'bulk-delete':
check_admin_referer( 'bulk-tags' );
- if ( !current_user_can( $tax->cap->delete_terms ) )
- wp_die( __( 'Cheatin’ uh?' ) );
+ if ( ! current_user_can( $tax->cap->delete_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to delete these items.' ) . '</p>',
+ 403
+ );
+ }
$tags = (array) $_REQUEST['delete_tags'];
foreach ( $tags as $tag_ID ) {
$location = 'edit-tags.php?taxonomy=' . $taxonomy;
if ( 'post' != $post_type )
$location .= '&post_type=' . $post_type;
- if ( $referer = wp_get_referer() ) {
- if ( false !== strpos( $referer, 'edit-tags.php' ) )
- $location = $referer;
+ if ( $referer && false !== strpos( $referer, 'edit-tags.php' ) ) {
+ $location = $referer;
}
$location = add_query_arg( 'message', 6, $location );
- wp_redirect( $location );
- exit;
-break;
+ break;
case 'edit':
- $title = $tax->labels->edit_item;
+ if ( ! isset( $_REQUEST['tag_ID'] ) ) {
+ break;
+ }
- $tag_ID = (int) $_REQUEST['tag_ID'];
+ $term_id = (int) $_REQUEST['tag_ID'];
+ $term = get_term( $term_id );
- $tag = get_term( $tag_ID, $taxonomy, OBJECT, 'edit' );
- if ( ! $tag )
+ if ( ! $term instanceof WP_Term ) {
wp_die( __( 'You attempted to edit an item that doesn’t exist. Perhaps it was deleted?' ) );
- require_once( ABSPATH . 'wp-admin/admin-header.php' );
- include( ABSPATH . 'wp-admin/edit-tag-form.php' );
+ }
-break;
+ wp_redirect( esc_url_raw( get_edit_term_link( $term_id, $taxonomy, $post_type ) ) );
+ exit;
case 'editedtag':
$tag_ID = (int) $_POST['tag_ID'];
check_admin_referer( 'update-tag_' . $tag_ID );
- if ( !current_user_can( $tax->cap->edit_terms ) )
- wp_die( __( 'Cheatin’ uh?' ) );
+ if ( ! current_user_can( $tax->cap->edit_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to edit this item.' ) . '</p>',
+ 403
+ );
+ }
$tag = get_term( $tag_ID, $taxonomy );
if ( ! $tag )
if ( 'post' != $post_type )
$location .= '&post_type=' . $post_type;
- if ( $referer = wp_get_original_referer() ) {
- if ( false !== strpos( $referer, 'edit-tags.php' ) )
- $location = $referer;
+ if ( $referer && false !== strpos( $referer, 'edit-tags.php' ) ) {
+ $location = $referer;
}
if ( $ret && !is_wp_error( $ret ) )
$location = add_query_arg( 'message', 3, $location );
else
- $location = add_query_arg( 'message', 5, $location );
-
- wp_redirect( $location );
- exit;
-break;
+ $location = add_query_arg( array( 'error' => true, 'message' => 5 ), $location );
+ break;
+}
-default:
-if ( ! empty($_REQUEST['_wp_http_referer']) ) {
+if ( ! $location && ! empty( $_REQUEST['_wp_http_referer'] ) ) {
$location = remove_query_arg( array('_wp_http_referer', '_wpnonce'), wp_unslash($_SERVER['REQUEST_URI']) );
+}
- if ( ! empty( $_REQUEST['paged'] ) )
- $location = add_query_arg( 'paged', (int) $_REQUEST['paged'] );
+if ( $location ) {
+ if ( ! empty( $_REQUEST['paged'] ) ) {
+ $location = add_query_arg( 'paged', (int) $_REQUEST['paged'], $location );
+ }
- wp_redirect( $location );
+ /**
+ * Filters the taxonomy redirect destination URL.
+ *
+ * @since 4.6.0
+ *
+ * @param string $location The destination URL.
+ * @param object $tax The taxonomy object.
+ */
+ wp_redirect( apply_filters( 'redirect_term_location', $location, $tax ) );
exit;
}
$help = '<p>' . __( 'When adding a new tag on this screen, you’ll fill in the following fields:' ) . '</p>';
$help .= '<ul>' .
- '<li>' . __( '<strong>Name</strong> - The name is how it appears on your site.' ) . '</li>';
+ '<li>' . __( '<strong>Name</strong> — The name is how it appears on your site.' ) . '</li>';
if ( ! global_terms_enabled() )
- $help .= '<li>' . __( '<strong>Slug</strong> - The “slug” is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.' ) . '</li>';
+ $help .= '<li>' . __( '<strong>Slug</strong> — The “slug” is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.' ) . '</li>';
if ( 'category' == $taxonomy )
- $help .= '<li>' . __( '<strong>Parent</strong> - Categories, unlike tags, can have a hierarchy. You might have a Jazz category, and under that have child categories for Bebop and Big Band. Totally optional. To create a subcategory, just choose another category from the Parent dropdown.' ) . '</li>';
+ $help .= '<li>' . __( '<strong>Parent</strong> — Categories, unlike tags, can have a hierarchy. You might have a Jazz category, and under that have child categories for Bebop and Big Band. Totally optional. To create a subcategory, just choose another category from the Parent dropdown.' ) . '</li>';
- $help .= '<li>' . __( '<strong>Description</strong> - The description is not prominent by default; however, some themes may display it.' ) . '</li>' .
+ $help .= '<li>' . __( '<strong>Description</strong> — The description is not prominent by default; however, some themes may display it.' ) . '</li>' .
'</ul>' .
'<p>' . __( 'You can change the display of this screen using the Screen Options tab to set how many items are displayed per screen and to display/hide columns in the table.' ) . '</p>';
$help = '<p><strong>' . __( 'For more information:' ) . '</strong></p>';
if ( 'category' == $taxonomy )
- $help .= '<p>' . __( '<a href="http://codex.wordpress.org/Posts_Categories_Screen" target="_blank">Documentation on Categories</a>' ) . '</p>';
+ $help .= '<p>' . __( '<a href="https://codex.wordpress.org/Posts_Categories_Screen" target="_blank">Documentation on Categories</a>' ) . '</p>';
elseif ( 'link_category' == $taxonomy )
- $help .= '<p>' . __( '<a href="http://codex.wordpress.org/Links_Link_Categories_Screen" target="_blank">Documentation on Link Categories</a>' ) . '</p>';
+ $help .= '<p>' . __( '<a href="https://codex.wordpress.org/Links_Link_Categories_Screen" target="_blank">Documentation on Link Categories</a>' ) . '</p>';
else
- $help .= '<p>' . __( '<a href="http://codex.wordpress.org/Posts_Tags_Screen" target="_blank">Documentation on Tags</a>' ) . '</p>';
+ $help .= '<p>' . __( '<a href="https://codex.wordpress.org/Posts_Tags_Screen" target="_blank">Documentation on Tags</a>' ) . '</p>';
$help .= '<p>' . __('<a href="https://wordpress.org/support/" target="_blank">Support Forums</a>') . '</p>';
require_once( ABSPATH . 'wp-admin/admin-header.php' );
-if ( !current_user_can($tax->cap->edit_terms) )
- wp_die( __('You are not allowed to edit this item.') );
-
-$messages = array();
-$messages['_item'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => __( 'Item added.' ),
- 2 => __( 'Item deleted.' ),
- 3 => __( 'Item updated.' ),
- 4 => __( 'Item not added.' ),
- 5 => __( 'Item not updated.' ),
- 6 => __( 'Items deleted.' )
-);
-$messages['category'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => __( 'Category added.' ),
- 2 => __( 'Category deleted.' ),
- 3 => __( 'Category updated.' ),
- 4 => __( 'Category not added.' ),
- 5 => __( 'Category not updated.' ),
- 6 => __( 'Categories deleted.' )
-);
-$messages['post_tag'] = array(
- 0 => '', // Unused. Messages start at index 1.
- 1 => __( 'Tag added.' ),
- 2 => __( 'Tag deleted.' ),
- 3 => __( 'Tag updated.' ),
- 4 => __( 'Tag not added.' ),
- 5 => __( 'Tag not updated.' ),
- 6 => __( 'Tags deleted.' )
-);
+if ( ! current_user_can( $tax->cap->edit_terms ) ) {
+ wp_die(
+ '<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
+ '<p>' . __( 'Sorry, you are not allowed to edit this item.' ) . '</p>',
+ 403
+ );
+}
-/**
- * Filter the messages displayed when a tag is updated.
- *
- * @since 3.7.0
- *
- * @param array $messages The messages to be displayed.
- */
-$messages = apply_filters( 'term_updated_messages', $messages );
-
-$message = false;
-if ( isset( $_REQUEST['message'] ) && ( $msg = (int) $_REQUEST['message'] ) ) {
- if ( isset( $messages[ $taxonomy ][ $msg ] ) )
- $message = $messages[ $taxonomy ][ $msg ];
- elseif ( ! isset( $messages[ $taxonomy ] ) && isset( $messages['_item'][ $msg ] ) )
- $message = $messages['_item'][ $msg ];
+/** Also used by the Edit Tag form */
+require_once( ABSPATH . 'wp-admin/includes/edit-tag-messages.php' );
+
+$class = ( isset( $_REQUEST['error'] ) ) ? 'error' : 'updated';
+
+if ( is_plugin_active( 'wpcat2tag-importer/wpcat2tag-importer.php' ) ) {
+ $import_link = admin_url( 'admin.php?import=wpcat2tag' );
+} else {
+ $import_link = admin_url( 'import.php' );
}
?>
<div class="wrap nosubsub">
-<h2><?php echo esc_html( $title );
-if ( !empty($_REQUEST['s']) )
- printf( '<span class="subtitle">' . __('Search results for “%s”') . '</span>', esc_html( wp_unslash($_REQUEST['s']) ) ); ?>
-</h2>
+<h1><?php echo esc_html( $title );
+if ( isset( $_REQUEST['s'] ) && strlen( $_REQUEST['s'] ) ) {
+ /* translators: %s: search keywords */
+ printf( '<span class="subtitle">' . __( 'Search results for “%s”' ) . '</span>', esc_html( wp_unslash( $_REQUEST['s'] ) ) );
+}
+?>
+</h1>
<?php if ( $message ) : ?>
-<div id="message" class="updated"><p><?php echo $message; ?></p></div>
-<?php $_SERVER['REQUEST_URI'] = remove_query_arg(array('message'), $_SERVER['REQUEST_URI']);
+<div id="message" class="<?php echo $class; ?> notice is-dismissible"><p><?php echo $message; ?></p></div>
+<?php $_SERVER['REQUEST_URI'] = remove_query_arg( array( 'message', 'error' ), $_SERVER['REQUEST_URI'] );
endif; ?>
<div id="ajax-response"></div>
-<form class="search-form" action="" method="get">
+<form class="search-form wp-clearfix" method="get">
<input type="hidden" name="taxonomy" value="<?php echo esc_attr($taxonomy); ?>" />
<input type="hidden" name="post_type" value="<?php echo esc_attr($post_type); ?>" />
<?php $wp_list_table->search_box( $tax->labels->search_items, 'tag' ); ?>
</form>
-<br class="clear" />
-
-<div id="col-container">
-
-<div id="col-right">
-<div class="col-wrap">
-<form id="posts-filter" action="" method="post">
-<input type="hidden" name="taxonomy" value="<?php echo esc_attr($taxonomy); ?>" />
-<input type="hidden" name="post_type" value="<?php echo esc_attr($post_type); ?>" />
-
-<?php $wp_list_table->display(); ?>
-
-<br class="clear" />
-</form>
-
-<?php if ( 'category' == $taxonomy ) : ?>
-<div class="form-wrap">
-<?php /** This filter is documented in wp-includes/category-template.php */ ?>
-<p><?php printf(__('<strong>Note:</strong><br />Deleting a category does not delete the posts in that category. Instead, posts that were only assigned to the deleted category are set to the category <strong>%s</strong>.'), apply_filters('the_category', get_cat_name(get_option('default_category')))) ?></p>
-<?php if ( current_user_can( 'import' ) ) : ?>
-<p><?php printf(__('Categories can be selectively converted to tags using the <a href="%s">category to tag converter</a>.'), 'import.php') ?></p>
-<?php endif; ?>
-</div>
-<?php elseif ( 'post_tag' == $taxonomy && current_user_can( 'import' ) ) : ?>
-<div class="form-wrap">
-<p><?php printf(__('Tags can be selectively converted to categories using the <a href="%s">tag to category converter</a>.'), 'import.php') ;?></p>
-</div>
-<?php endif;
-
-/**
- * Fires after the taxonomy list table.
- *
- * The dynamic portion of the hook name, $taxonomy, refers to the taxonomy slug.
- *
- * @since 3.0.0
- *
- * @param string $taxonomy The taxonomy name.
- */
-do_action( "after-{$taxonomy}-table", $taxonomy );
-?>
-</div>
-</div><!-- /col-right -->
+<div id="col-container" class="wp-clearfix">
<div id="col-left">
<div class="col-wrap">
<?php
-if ( !is_null( $tax->labels->popular_items ) ) {
- if ( current_user_can( $tax->cap->edit_terms ) )
- $tag_cloud = wp_tag_cloud( array( 'taxonomy' => $taxonomy, 'post_type' => $post_type, 'echo' => false, 'link' => 'edit' ) );
- else
- $tag_cloud = wp_tag_cloud( array( 'taxonomy' => $taxonomy, 'echo' => false ) );
-
- if ( $tag_cloud ) :
- ?>
-<div class="tagcloud">
-<h3><?php echo $tax->labels->popular_items; ?></h3>
-<?php echo $tag_cloud; unset( $tag_cloud ); ?>
-</div>
-<?php
-endif;
-}
-
if ( current_user_can($tax->cap->edit_terms) ) {
if ( 'category' == $taxonomy ) {
/**
/**
* Fires before the Add Term form for all taxonomies.
*
- * The dynamic portion of the hook name, $taxonomy, refers to the taxonomy slug.
+ * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug.
*
* @since 3.0.0
*
?>
<div class="form-wrap">
-<h3><?php echo $tax->labels->add_new_item; ?></h3>
+<h2><?php echo $tax->labels->add_new_item; ?></h2>
+<form id="addtag" method="post" action="edit-tags.php" class="validate"
<?php
/**
* Fires at the beginning of the Add Tag form.
*
- * The dynamic portion of the hook name, $taxonomy, refers to the taxonomy slug.
+ * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug.
*
* @since 3.7.0
*/
-?>
-<form id="addtag" method="post" action="edit-tags.php" class="validate"<?php do_action( "{$taxonomy}_term_new_form_tag" ); ?>>
+do_action( "{$taxonomy}_term_new_form_tag" );
+?>>
<input type="hidden" name="action" value="add-tag" />
<input type="hidden" name="screen" value="<?php echo esc_attr($current_screen->id); ?>" />
<input type="hidden" name="taxonomy" value="<?php echo esc_attr($taxonomy); ?>" />
<input type="hidden" name="post_type" value="<?php echo esc_attr($post_type); ?>" />
<?php wp_nonce_field('add-tag', '_wpnonce_add-tag'); ?>
-<div class="form-field form-required">
- <label for="tag-name"><?php _ex('Name', 'Taxonomy Name'); ?></label>
+<div class="form-field form-required term-name-wrap">
+ <label for="tag-name"><?php _ex( 'Name', 'term name' ); ?></label>
<input name="tag-name" id="tag-name" type="text" value="" size="40" aria-required="true" />
<p><?php _e('The name is how it appears on your site.'); ?></p>
</div>
<?php if ( ! global_terms_enabled() ) : ?>
-<div class="form-field">
- <label for="tag-slug"><?php _ex('Slug', 'Taxonomy Slug'); ?></label>
+<div class="form-field term-slug-wrap">
+ <label for="tag-slug"><?php _e( 'Slug' ); ?></label>
<input name="slug" id="tag-slug" type="text" value="" size="40" />
<p><?php _e('The “slug” is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.'); ?></p>
</div>
<?php endif; // global_terms_enabled() ?>
<?php if ( is_taxonomy_hierarchical($taxonomy) ) : ?>
-<div class="form-field">
- <label for="parent"><?php _ex('Parent', 'Taxonomy Parent'); ?></label>
+<div class="form-field term-parent-wrap">
+ <label for="parent"><?php _ex( 'Parent', 'term parent' ); ?></label>
<?php
$dropdown_args = array(
'hide_empty' => 0,
);
/**
- * Filter the taxonomy parent drop-down on the Edit Term page.
+ * Filters the taxonomy parent drop-down on the Edit Term page.
*
* @since 3.7.0
+ * @since 4.2.0 Added `$context` parameter.
*
* @param array $dropdown_args {
* An array of taxonomy parent drop-down arguments.
* @type string $show_option_none Label to display if there are no terms. Default 'None'.
* }
* @param string $taxonomy The taxonomy slug.
+ * @param string $context Filter context. Accepts 'new' or 'edit'.
*/
- $dropdown_args = apply_filters( 'taxonomy_parent_dropdown_args', $dropdown_args, $taxonomy );
+ $dropdown_args = apply_filters( 'taxonomy_parent_dropdown_args', $dropdown_args, $taxonomy, 'new' );
+
wp_dropdown_categories( $dropdown_args );
?>
<?php if ( 'category' == $taxonomy ) : // @todo: Generic text for hierarchical taxonomies ?>
<?php endif; ?>
</div>
<?php endif; // is_taxonomy_hierarchical() ?>
-<div class="form-field">
- <label for="tag-description"><?php _ex('Description', 'Taxonomy Description'); ?></label>
+<div class="form-field term-description-wrap">
+ <label for="tag-description"><?php _e( 'Description' ); ?></label>
<textarea name="description" id="tag-description" rows="5" cols="40"></textarea>
<p><?php _e('The description is not prominent by default; however, some themes may show it.'); ?></p>
</div>
}
/**
- * Fires after the Add Term form fields for hierarchical taxonomies.
+ * Fires after the Add Term form fields.
*
- * The dynamic portion of the hook name, $taxonomy, refers to the taxonomy slug.
+ * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug.
*
* @since 3.0.0
*
/**
* Fires at the end of the Add Term form for all taxonomies.
*
- * The dynamic portion of the hook name, $taxonomy, refers to the taxonomy slug.
+ * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug.
*
* @since 3.0.0
*
do_action( "{$taxonomy}_add_form", $taxonomy );
?>
</form></div>
-<?php } ?>
+<?php }
+
+if ( ! is_null( $tax->labels->popular_items ) ) {
+ if ( current_user_can( $tax->cap->edit_terms ) ) {
+ $tag_cloud = wp_tag_cloud( array( 'taxonomy' => $taxonomy, 'post_type' => $post_type, 'echo' => false, 'link' => 'edit' ) );
+ } else {
+ $tag_cloud = wp_tag_cloud( array( 'taxonomy' => $taxonomy, 'echo' => false ) );
+ }
+
+ if ( $tag_cloud ) :
+ ?>
+<div class="tagcloud">
+<h2><?php echo $tax->labels->popular_items; ?></h2>
+<?php echo $tag_cloud; unset( $tag_cloud ); ?>
+</div>
+<?php
+ endif;
+}
+
+?>
</div>
</div><!-- /col-left -->
+<div id="col-right">
+<div class="col-wrap">
+<form id="posts-filter" method="post">
+<input type="hidden" name="taxonomy" value="<?php echo esc_attr( $taxonomy ); ?>" />
+<input type="hidden" name="post_type" value="<?php echo esc_attr( $post_type ); ?>" />
+
+<?php $wp_list_table->display(); ?>
+
+</form>
+
+<?php if ( 'category' == $taxonomy ) : ?>
+<div class="form-wrap edit-term-notes">
+<p>
+ <?php
+ echo '<strong>' . __( 'Note:' ) . '</strong><br />';
+ printf(
+ /* translators: %s: default category */
+ __( 'Deleting a category does not delete the posts in that category. Instead, posts that were only assigned to the deleted category are set to the category %s.' ),
+ /** This filter is documented in wp-includes/category-template.php */
+ '<strong>' . apply_filters( 'the_category', get_cat_name( get_option( 'default_category') ) ) . '</strong>'
+ );
+ ?>
+</p>
+<?php if ( current_user_can( 'import' ) ) : ?>
+<p><?php printf( __( 'Categories can be selectively converted to tags using the <a href="%s">category to tag converter</a>.' ), esc_url( $import_link ) ) ?></p>
+<?php endif; ?>
+</div>
+<?php elseif ( 'post_tag' == $taxonomy && current_user_can( 'import' ) ) : ?>
+<div class="form-wrap edit-term-notes">
+<p><?php printf( __( 'Tags can be selectively converted to categories using the <a href="%s">tag to category converter</a>.' ), esc_url( $import_link ) ) ;?></p>
+</div>
+<?php endif;
+
+/**
+ * Fires after the taxonomy list table.
+ *
+ * The dynamic portion of the hook name, `$taxonomy`, refers to the taxonomy slug.
+ *
+ * @since 3.0.0
+ *
+ * @param string $taxonomy The taxonomy name.
+ */
+do_action( "after-{$taxonomy}-table", $taxonomy );
+?>
+
+</div>
+</div><!-- /col-right -->
+
</div><!-- /col-container -->
</div><!-- /wrap -->
+
+<?php if ( ! wp_is_mobile() ) : ?>
<script type="text/javascript">
try{document.forms.addtag['tag-name'].focus();}catch(e){}
</script>
-<?php $wp_list_table->inline_edit(); ?>
-
<?php
-break;
-}
+endif;
+
+$wp_list_table->inline_edit();
include( ABSPATH . 'wp-admin/admin-footer.php' );