WordPress 3.4
[autoinstalls/wordpress.git] / wp-admin / edit-tags.php
index 19912705408f3ce0adead7c1431cbb6ac3f205a1..44b2aa57e9bd5291018af026ca4ae14dbfcb1c7b 100644 (file)
@@ -1,6 +1,6 @@
 <?php
 /**
- * Edit Tags Administration Panel.
+ * Edit Tags Administration Screen.
  *
  * @package WordPress
  * @subpackage Administration
@@ -9,56 +9,59 @@
 /** WordPress Administration Bootstrap */
 require_once('./admin.php');
 
-wp_reset_vars( array('action', 'tag', 'taxonomy', 'post_type') );
+if ( ! $taxnow )
+       wp_die( __( 'Invalid taxonomy' ) );
 
-if ( empty($taxonomy) )
-       $taxonomy = 'post_tag';
+$tax = get_taxonomy( $taxnow );
 
-if ( !taxonomy_exists($taxonomy) )
-       wp_die(__('Invalid taxonomy'));
+if ( ! $tax )
+       wp_die( __( 'Invalid taxonomy' ) );
 
-$tax = get_taxonomy($taxonomy);
+if ( ! current_user_can( $tax->cap->manage_terms ) )
+       wp_die( __( 'Cheatin&#8217; uh?' ) );
 
-$title = $tax->labels->name;
+$wp_list_table = _get_list_table('WP_Terms_List_Table');
+$pagenum = $wp_list_table->get_pagenum();
 
-if ( empty($post_type) || !in_array( $post_type, get_post_types( array('public' => true) ) ) )
-       $post_type = 'post';
+$title = $tax->labels->name;
 
 if ( 'post' != $post_type ) {
        $parent_file = "edit.php?post_type=$post_type";
        $submenu_file = "edit-tags.php?taxonomy=$taxonomy&amp;post_type=$post_type";
+} else if ( 'link_category' == $tax->name ) {
+       $parent_file = 'link-manager.php';
+       $submenu_file = 'edit-tags.php?taxonomy=link_category';
 } else {
        $parent_file = 'edit.php';
        $submenu_file = "edit-tags.php?taxonomy=$taxonomy";
 }
 
-if ( isset( $_GET['action'] ) && isset($_GET['delete_tags']) && ( 'delete' == $_GET['action'] || 'delete' == $_GET['action2'] ) )
-       $action = 'bulk-delete';
+add_screen_option( 'per_page', array('label' => $title, 'default' => 20, 'option' => 'edit_' . $tax->name . '_per_page') );
 
-switch($action) {
+switch ( $wp_list_table->current_action() ) {
 
 case 'add-tag':
 
-       check_admin_referer('add-tag');
+       check_admin_referer( 'add-tag', '_wpnonce_add-tag' );
 
-       if ( !current_user_can($tax->cap->edit_terms) )
-               wp_die(__('Cheatin&#8217; uh?'));
+       if ( !current_user_can( $tax->cap->edit_terms ) )
+               wp_die( __( 'Cheatin&#8217; uh?' ) );
 
-       $ret = wp_insert_term($_POST['tag-name'], $taxonomy, $_POST);
+       $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') )
+               if ( false !== strpos( $referer, 'edit-tags.php' ) )
                        $location = $referer;
        }
 
        if ( $ret && !is_wp_error( $ret ) )
-               $location = add_query_arg('message', 1, $location);
+               $location = add_query_arg( 'message', 1, $location );
        else
-               $location = add_query_arg('message', 4, $location);
-       wp_redirect($location);
+               $location = add_query_arg( 'message', 4, $location );
+       wp_redirect( $location );
        exit;
 break;
 
@@ -67,50 +70,50 @@ case 'delete':
        if ( 'post' != $post_type )
                $location .= '&post_type=' . $post_type;
        if ( $referer = wp_get_referer() ) {
-               if ( false !== strpos($referer, 'edit-tags.php') )
+               if ( false !== strpos( $referer, 'edit-tags.php' ) )
                        $location = $referer;
        }
 
-       if ( !isset( $_GET['tag_ID'] ) ) {
-               wp_redirect($location);
+       if ( !isset( $_REQUEST['tag_ID'] ) ) {
+               wp_redirect( $location );
                exit;
        }
 
-       $tag_ID = (int) $_GET['tag_ID'];
-       check_admin_referer('delete-tag_' .  $tag_ID);
+       $tag_ID = (int) $_REQUEST['tag_ID'];
+       check_admin_referer( 'delete-tag_' . $tag_ID );
 
-       if ( !current_user_can($tax->cap->delete_terms) )
-               wp_die(__('Cheatin&#8217; uh?'));
+       if ( !current_user_can( $tax->cap->delete_terms ) )
+               wp_die( __( 'Cheatin&#8217; uh?' ) );
 
-       wp_delete_term( $tag_ID, $taxonomy);
+       wp_delete_term( $tag_ID, $taxonomy );
 
-       $location = add_query_arg('message', 2, $location);
-       wp_redirect($location);
+       $location = add_query_arg( 'message', 2, $location );
+       wp_redirect( $location );
        exit;
 
 break;
 
 case 'bulk-delete':
-       check_admin_referer('bulk-tags');
+       check_admin_referer( 'bulk-tags' );
 
-       if ( !current_user_can($tax->cap->delete_terms) )
-               wp_die(__('Cheatin&#8217; uh?'));
+       if ( !current_user_can( $tax->cap->delete_terms ) )
+               wp_die( __( 'Cheatin&#8217; uh?' ) );
 
-       $tags = (array) $_GET['delete_tags'];
-       foreach( $tags as $tag_ID ) {
-               wp_delete_term( $tag_ID, $taxonomy);
+       $tags = (array) $_REQUEST['delete_tags'];
+       foreach ( $tags as $tag_ID ) {
+               wp_delete_term( $tag_ID, $taxonomy );
        }
 
        $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') )
+               if ( false !== strpos( $referer, 'edit-tags.php' ) )
                        $location = $referer;
        }
 
-       $location = add_query_arg('message', 6, $location);
-       wp_redirect($location);
+       $location = add_query_arg( 'message', 6, $location );
+       wp_redirect( $location );
        exit;
 
 break;
@@ -118,91 +121,137 @@ break;
 case 'edit':
        $title = $tax->labels->edit_item;
 
-       require_once ('admin-header.php');
-       $tag_ID = (int) $_GET['tag_ID'];
+       $tag_ID = (int) $_REQUEST['tag_ID'];
 
-       $tag = get_term($tag_ID, $taxonomy, OBJECT, 'edit');
-       include('./edit-tag-form.php');
+       $tag = get_term( $tag_ID, $taxonomy, OBJECT, 'edit' );
+       if ( ! $tag )
+               wp_die( __( 'You attempted to edit an item that doesn&#8217;t exist. Perhaps it was deleted?' ) );
+       require_once ( 'admin-header.php' );
+       include( './edit-tag-form.php' );
 
 break;
 
 case 'editedtag':
        $tag_ID = (int) $_POST['tag_ID'];
-       check_admin_referer('update-tag_' . $tag_ID);
+       check_admin_referer( 'update-tag_' . $tag_ID );
 
-       if ( !current_user_can($tax->cap->edit_terms) )
-               wp_die(__('Cheatin&#8217; uh?'));
+       if ( !current_user_can( $tax->cap->edit_terms ) )
+               wp_die( __( 'Cheatin&#8217; uh?' ) );
 
-       $ret = wp_update_term($tag_ID, $taxonomy, $_POST);
+       $tag = get_term( $tag_ID, $taxonomy );
+       if ( ! $tag )
+               wp_die( __( 'You attempted to edit an item that doesn&#8217;t exist. Perhaps it was deleted?' ) );
+
+       $ret = wp_update_term( $tag_ID, $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') )
+               if ( false !== strpos( $referer, 'edit-tags.php' ) )
                        $location = $referer;
        }
 
        if ( $ret && !is_wp_error( $ret ) )
-               $location = add_query_arg('message', 3, $location);
+               $location = add_query_arg( 'message', 3, $location );
        else
-               $location = add_query_arg('message', 5, $location);
+               $location = add_query_arg( 'message', 5, $location );
 
-       wp_redirect($location);
+       wp_redirect( $location );
        exit;
 break;
 
 default:
+if ( ! empty($_REQUEST['_wp_http_referer']) ) {
+       $location = remove_query_arg( array('_wp_http_referer', '_wpnonce'), stripslashes($_SERVER['REQUEST_URI']) );
+
+       if ( ! empty( $_REQUEST['paged'] ) )
+               $location = add_query_arg( 'paged', (int) $_REQUEST['paged'] );
+
+       wp_redirect( $location );
+       exit;
+}
 
-if ( ! empty($_GET['_wp_http_referer']) ) {
-        wp_redirect( remove_query_arg( array('_wp_http_referer', '_wpnonce'), stripslashes($_SERVER['REQUEST_URI']) ) );
-        exit;
+$wp_list_table->prepare_items();
+$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' );
+
+if ( $pagenum > $total_pages && $total_pages > 0 ) {
+       wp_redirect( add_query_arg( 'paged', $total_pages ) );
+       exit;
 }
 
 wp_enqueue_script('admin-tags');
 if ( current_user_can($tax->cap->edit_terms) )
        wp_enqueue_script('inline-edit-tax');
 
-if ( 'category' == $taxonomy || 'post_tag' == $taxonomy ) {
+if ( 'category' == $taxonomy || 'link_category' == $taxonomy || 'post_tag' == $taxonomy  ) {
+       $help ='';
        if ( 'category' == $taxonomy )
-               $help = '<p>' . sprintf(__('You can use categories to define sections of your site and group related posts. The default category is &#8220;Uncategorized&#8221; until you change it in your <a href="%s">writing settings</a>.'), 'options-writing.php') . '</p>';
+               $help = '<p>' . sprintf(__( 'You can use categories to define sections of your site and group related posts. The default category is &#8220;Uncategorized&#8221; until you change it in your <a href="%s">writing settings</a>.' ) , 'options-writing.php' ) . '</p>';
+       elseif ( 'link_category' == $taxonomy )
+               $help = '<p>' . __( 'You can create groups of links by using Link Categories. Link Category names must be unique and Link Categories are separate from the categories you use for posts.' ) . '</p>';
        else
-               $help = '<p>' . __('You can assign keywords to your posts using Post Tags. Unlike categories, tags have no hierarchy, meaning there&#8217;s no relationship from one tag to another.') . '</p>';
+               $help = '<p>' . __( 'You can assign keywords to your posts using <strong>tags</strong>. Unlike categories, tags have no hierarchy, meaning there&#8217;s no relationship from one tag to another.' ) . '</p>';
 
-       $help .='<p>' . __('What&#8217;s the difference between categories and tags? Normally, tags are ad-hoc keywords that identify important information in your post (names, subjects, etc) that may or may not recur in other posts, while categories are pre-determined sections. If you think of your site like a book, the categories are like the Table of Contents and the tags are like the terms in the index.') . '</p>';
-
-       if ( 'category' == $taxonomy )
-               $help .= '<p>' . __('When adding a new category on this screen, you&#8217;ll fill in the following fields:') . '</p>';
+       if ( 'link_category' == $taxonomy )
+               $help .= '<p>' . __( 'You can delete Link Categories in the Bulk Action pulldown, but that action does not delete the links within the category. Instead, it moves them to the default Link Category.' ) . '</p>';
        else
-               $help .= '<p>' . __('When adding a new tag on this screen, you&#8217;ll fill in the following fields:') . '</p>';
+               $help .='<p>' . __( 'What&#8217;s the difference between categories and tags? Normally, tags are ad-hoc keywords that identify important information in your post (names, subjects, etc) that may or may not recur in other posts, while categories are pre-determined sections. If you think of your site like a book, the categories are like the Table of Contents and the tags are like the terms in the index.' ) . '</p>';
 
-       $help .= '<ul>' .
-               '<li>' . __('<strong>Name</strong> - The name is how it appears on your site.') . '</li>';
-       if ( ! global_terms_enabled() )
-               $help .= '<li>' . __('<strong>Slug</strong> - The &#8220;slug&#8221; is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.') . '</li>';
+       get_current_screen()->add_help_tab( array(
+               'id'      => 'overview',
+               'title'   => __('Overview'),
+               'content' => $help,
+       ) );
 
-       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 children categories for Bebop and Big Band. Totally optional. To create a subcategory, just choose another category from the Parent dropdown.') . '</li>';
+       if ( 'category' == $taxonomy || 'post_tag' == $taxonomy ) {
+               if ( 'category' == $taxonomy )
+                       $help = '<p>' . __( 'When adding a new category on this screen, you&#8217;ll fill in the following fields:' ) . '</p>';
+               else
+                       $help = '<p>' . __( 'When adding a new tag on this screen, you&#8217;ll fill in the following fields:' ) . '</p>';
+
+               $help .= '<ul>' .
+               '<li>' . __( '<strong>Name</strong> - The name is how it appears on your site.' ) . '</li>';
+
+               if ( ! global_terms_enabled() )
+                       $help .= '<li>' . __( '<strong>Slug</strong> - The &#8220;slug&#8221; is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.' ) . '</li>';
 
-       $help .= '<li>' . __('<strong>Description</strong> - The description is not prominent by default; however, some themes may display it.') . '</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 children 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>' .
                '</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>' .
-               '<p><strong>' . __('For more information:') . '</strong></p>';
+               '<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>';
+
+               get_current_screen()->add_help_tab( array(
+                       'id'      => 'adding-terms',
+                       'title'   => 'category' == $taxonomy ? __( 'Adding Categories' ) : __( 'Adding Tags' ),
+                       'content' => $help,
+               ) );
+       }
+
+       $help = '<p><strong>' . __( 'For more information:' ) . '</strong></p>';
 
        if ( 'category' == $taxonomy )
-               $help .= '<p>' . __('<a href="http://codex.wordpress.org/Manage_Categories_SubPanel" target="_blank">Categories Documentation</a>') . '</p>';
+               $help .= '<p>' . __( '<a href="http://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>';
        else
-               $help .= '<p>' . __('<a href="http://codex.wordpress.org/Post_Tags_SubPanel" target="_blank">Tags Documentation</a>') . '</p>';
+               $help .= '<p>' . __( '<a href="http://codex.wordpress.org/Posts_Tags_Screen" target="_blank">Documentation on Tags</a>' ) . '</p>';
 
        $help .= '<p>' . __('<a href="http://wordpress.org/support/" target="_blank">Support Forums</a>') . '</p>';
 
-       add_contextual_help($current_screen, $help);
-       unset($help);
+       get_current_screen()->set_help_sidebar( $help );
+
+       unset( $help );
 }
 
 require_once ('admin-header.php');
 
+if ( !current_user_can($tax->cap->edit_terms) )
+       wp_die( __('You are not allowed to edit this item.') );
+
 $messages[1] = __('Item added.');
 $messages[2] = __('Item deleted.');
 $messages[3] = __('Item updated.');
@@ -215,11 +264,11 @@ $messages[6] = __('Items deleted.');
 <div class="wrap nosubsub">
 <?php screen_icon(); ?>
 <h2><?php echo esc_html( $title );
-if ( !empty($_GET['s']) )
-       printf( '<span class="subtitle">' . __('Search results for &#8220;%s&#8221;') . '</span>', esc_html( stripslashes($_GET['s']) ) ); ?>
+if ( !empty($_REQUEST['s']) )
+       printf( '<span class="subtitle">' . __('Search results for &#8220;%s&#8221;') . '</span>', esc_html( stripslashes($_REQUEST['s']) ) ); ?>
 </h2>
 
-<?php if ( isset($_GET['message']) && ( $msg = (int) $_GET['message'] ) ) : ?>
+<?php if ( isset($_REQUEST['message']) && ( $msg = (int) $_REQUEST['message'] ) ) : ?>
 <div id="message" class="updated"><p><?php echo $messages[$msg]; ?></p></div>
 <?php $_SERVER['REQUEST_URI'] = remove_query_arg(array('message'), $_SERVER['REQUEST_URI']);
 endif; ?>
@@ -228,11 +277,9 @@ endif; ?>
 <form class="search-form" action="" 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); ?>" />
-<p class="search-box">
-       <label class="screen-reader-text" for="tag-search-input"><?php echo $tax->labels->search_items; ?>:</label>
-       <input type="text" id="tag-search-input" name="s" value="<?php _admin_search_query(); ?>" />
-       <input type="submit" value="<?php echo esc_attr( $tax->labels->search_items );  ?>" class="button" />
-</p>
+
+<?php $wp_list_table->search_box( $tax->labels->search_items, 'tag' ); ?>
+
 </form>
 <br class="clear" />
 
@@ -240,91 +287,11 @@ endif; ?>
 
 <div id="col-right">
 <div class="col-wrap">
-<form id="posts-filter" action="" method="get">
+<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); ?>" />
-<div class="tablenav">
-<?php
-$pagenum = isset( $_GET['pagenum'] ) ? absint( $_GET['pagenum'] ) : 0;
-if ( empty($pagenum) )
-       $pagenum = 1;
-
-$tags_per_page = (int) get_user_option( 'edit_' .  $taxonomy . '_per_page' );
 
-if ( empty($tags_per_page) || $tags_per_page < 1 )
-       $tags_per_page = 20;
-
-if ( 'post_tag' == $taxonomy ) {
-       $tags_per_page = apply_filters( 'edit_tags_per_page', $tags_per_page );
-       $tags_per_page = apply_filters( 'tagsperpage', $tags_per_page ); // Old filter
-} elseif ( 'category' == $taxonomy ) {
-       $tags_per_page = apply_filters( 'edit_categories_per_page', $tags_per_page ); // Old filter
-} else {
-       $tags_per_page = apply_filters( 'edit_' . $taxonomy . '_per_page', $tags_per_page );
-}
-
-$searchterms = !empty($_GET['s']) ? trim(stripslashes($_GET['s'])) : '';
-
-$page_links = paginate_links( array(
-       'base' => add_query_arg( 'pagenum', '%#%' ),
-       'format' => '',
-       'prev_text' => __('&laquo;'),
-       'next_text' => __('&raquo;'),
-       'total' => ceil(wp_count_terms($taxonomy, array('search' => $searchterms)) / $tags_per_page),
-       'current' => $pagenum
-));
-
-if ( $page_links )
-       echo "<div class='tablenav-pages'>$page_links</div>";
-?>
-
-<div class="alignleft actions">
-<select name="action">
-<option value="" selected="selected"><?php _e('Bulk Actions'); ?></option>
-<option value="delete"><?php _e('Delete'); ?></option>
-</select>
-<input type="submit" value="<?php esc_attr_e('Apply'); ?>" name="doaction" id="doaction" class="button-secondary action" />
-<?php wp_nonce_field('bulk-tags'); ?>
-</div>
-
-<br class="clear" />
-</div>
-
-<div class="clear"></div>
-<table class="widefat tag fixed" cellspacing="0">
-       <thead>
-       <tr>
-<?php print_column_headers($current_screen); ?>
-       </tr>
-       </thead>
-
-       <tfoot>
-       <tr>
-<?php print_column_headers($current_screen, false); ?>
-       </tr>
-       </tfoot>
-
-       <tbody id="the-list" class="list:tag">
-<?php tag_rows( $pagenum, $tags_per_page, $searchterms, $taxonomy ); ?>
-       </tbody>
-</table>
-
-<div class="tablenav">
-<?php
-if ( $page_links )
-       echo "<div class='tablenav-pages'>$page_links</div>";
-?>
-
-<div class="alignleft actions">
-<select name="action2">
-<option value="" selected="selected"><?php _e('Bulk Actions'); ?></option>
-<option value="delete"><?php _e('Delete'); ?></option>
-</select>
-<input type="submit" value="<?php esc_attr_e('Apply'); ?>" name="doaction2" id="doaction2" class="button-secondary action" />
-</div>
-
-<br class="clear" />
-</div>
+<?php $wp_list_table->display(); ?>
 
 <br class="clear" />
 </form>
@@ -352,7 +319,7 @@ do_action('after-' . $taxonomy . '-table', $taxonomy);
 
 <?php
 
-if ( !is_taxonomy_hierarchical($taxonomy) ) {
+if ( !is_null( $tax->labels->popular_items ) ) {
        if ( current_user_can( $tax->cap->edit_terms ) )
                $tag_cloud = wp_tag_cloud( array( 'taxonomy' => $taxonomy, 'echo' => false, 'link' => 'edit' ) );
        else
@@ -369,10 +336,14 @@ endif;
 }
 
 if ( current_user_can($tax->cap->edit_terms) ) {
+       // Back compat hooks. Deprecated in preference to {$taxonomy}_pre_add_form
        if ( 'category' == $taxonomy )
-               do_action('add_category_form_pre', (object)array('parent' => 0) );  // Back compat hook. Deprecated in preference to $taxonomy_pre_add_form
+               do_action('add_category_form_pre', (object)array('parent' => 0) );
+       elseif ( 'link_category' == $taxonomy )
+               do_action('add_link_category_form_pre', (object)array('parent' => 0) );
        else
-               do_action('add_tag_form_pre', $taxonomy); // Back compat hook. Applies to all Taxonomies -not- categories
+               do_action('add_tag_form_pre', $taxonomy);
+
        do_action($taxonomy . '_pre_add_form', $taxonomy);
 ?>
 
@@ -382,7 +353,8 @@ if ( current_user_can($tax->cap->edit_terms) ) {
 <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); ?>" />
-<?php wp_nonce_field('add-tag'); ?>
+<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>
@@ -395,7 +367,7 @@ if ( current_user_can($tax->cap->edit_terms) ) {
        <input name="slug" id="tag-slug" type="text" value="" size="40" />
        <p><?php _e('The &#8220;slug&#8221; is the URL-friendly version of the name. It is usually all lowercase and contains only letters, numbers, and hyphens.'); ?></p>
 </div>
-<?php endif; // is_multisite() ?>
+<?php endif; // global_terms_enabled() ?>
 <?php if ( is_taxonomy_hierarchical($taxonomy) ) : ?>
 <div class="form-field">
        <label for="parent"><?php _ex('Parent', 'Taxonomy Parent'); ?></label>
@@ -415,13 +387,17 @@ if ( current_user_can($tax->cap->edit_terms) ) {
 if ( ! is_taxonomy_hierarchical($taxonomy) )
        do_action('add_tag_form_fields', $taxonomy);
 do_action($taxonomy . '_add_form_fields', $taxonomy);
-?>
-<p class="submit"><input type="submit" class="button" name="submit" id="submit" value="<?php echo esc_attr( $tax->labels->add_new_item ); ?>" /></p>
-<?php
+
+submit_button( $tax->labels->add_new_item, 'button' );
+
+// Back compat hooks. Deprecated in preference to {$taxonomy}_add_form
 if ( 'category' == $taxonomy )
-       do_action('edit_category_form', (object)array('parent' => 0) );  // Back compat hook. Deprecated in preference to $taxonomy_add_form
+       do_action('edit_category_form', (object)array('parent' => 0) );
+elseif ( 'link_category' == $taxonomy )
+       do_action('edit_link_category_form', (object)array('parent' => 0) );
 else
-       do_action('add_tag_form', $taxonomy); // Back compat hook. Applies to all Taxonomies -not- categories
+       do_action('add_tag_form', $taxonomy);
+
 do_action($taxonomy . '_add_form', $taxonomy);
 ?>
 </form></div>
@@ -433,12 +409,10 @@ do_action($taxonomy . '_add_form', $taxonomy);
 </div><!-- /col-container -->
 </div><!-- /wrap -->
 
-<?php inline_edit_term_row('edit-tags', $taxonomy); ?>
+<?php $wp_list_table->inline_edit(); ?>
 
 <?php
 break;
 }
 
 include('./admin-footer.php');
-
-?>