X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/58f607a1de715c9bca69340a4d6fb9e1b9c2bed2..e0feb3b2e5b436a06bbb04fbc838d1cd6ec95399:/wp-admin/edit-tags.php diff --git a/wp-admin/edit-tags.php b/wp-admin/edit-tags.php index 057aa489..db8319cd 100644 --- a/wp-admin/edit-tags.php +++ b/wp-admin/edit-tags.php @@ -1,244 +1,334 @@ cap->manage_terms ) ) + wp_die( __( 'Cheatin’ uh?' ), 403 ); -if ( ! current_user_can($tax->cap->manage_terms) ) - wp_die(__('Cheatin’ uh?')); +/** + * $post_type is set when the WP_Terms_List_Table instance is created + * + * @global string $post_type + */ +global $post_type; -$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"; + $parent_file = ( 'attachment' == $post_type ) ? 'upload.php' : "edit.php?post_type=$post_type"; $submenu_file = "edit-tags.php?taxonomy=$taxonomy&post_type=$post_type"; +} elseif ( '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( 'default' => 20, 'option' => 'edit_' . $tax->name . '_per_page' ) ); + +$location = false; -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’ uh?')); + if ( !current_user_can( $tax->cap->edit_terms ) ) + wp_die( __( 'Cheatin’ uh?' ), 403 ); - $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); - 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') ) + if ( false !== strpos( $referer, 'edit-tags.php' ) ) $location = $referer; } - if ( !isset( $_GET['tag_ID'] ) ) { - wp_redirect($location); - exit; + if ( ! isset( $_REQUEST['tag_ID'] ) ) { + break; } - $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’ uh?')); + if ( !current_user_can( $tax->cap->delete_terms ) ) + wp_die( __( 'Cheatin’ uh?' ), 403 ); - wp_delete_term( $tag_ID, $taxonomy); + wp_delete_term( $tag_ID, $taxonomy ); - $location = add_query_arg('message', 2, $location); - wp_redirect($location); - exit; + $location = add_query_arg( 'message', 2, $location ); -break; + 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’ uh?')); + if ( !current_user_can( $tax->cap->delete_terms ) ) + wp_die( __( 'Cheatin’ uh?' ), 403 ); - $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); - exit; + $location = add_query_arg( 'message', 6, $location ); -break; + 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']; - if ( !current_user_can($tax->cap->edit_terms) ) - wp_die( __('You are not allowed to edit this item.') ); + $tag = get_term( $tag_ID, $taxonomy, OBJECT, 'edit' ); + if ( ! $tag ) + 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' ); + include( ABSPATH . 'wp-admin/admin-footer.php' ); - $tag = get_term($tag_ID, $taxonomy, OBJECT, 'edit'); - include('./edit-tag-form.php'); - -break; + exit; 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’ uh?' ), 403 ); - if ( !current_user_can($tax->cap->edit_terms) ) - wp_die(__('Cheatin’ uh?')); + $tag = get_term( $tag_ID, $taxonomy ); + if ( ! $tag ) + wp_die( __( 'You attempted to edit an item that doesn’t exist. Perhaps it was deleted?' ) ); - $ret = wp_update_term($tag_ID, $taxonomy, $_POST); + $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( array( 'error' => true, 'message' => 5 ), $location ); + break; +} + +if ( ! $location && ! empty( $_REQUEST['_wp_http_referer'] ) ) { + $location = remove_query_arg( array('_wp_http_referer', '_wpnonce'), wp_unslash($_SERVER['REQUEST_URI']) ); +} - wp_redirect($location); +if ( $location ) { + if ( ! empty( $_REQUEST['paged'] ) ) { + $location = add_query_arg( 'paged', (int) $_REQUEST['paged'], $location ); + } + wp_redirect( $location ); exit; -break; +} -default: +$wp_list_table->prepare_items(); +$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' ); -if ( ! empty($_GET['_wp_http_referer']) ) { - wp_redirect( remove_query_arg( array('_wp_http_referer', '_wpnonce'), stripslashes($_SERVER['REQUEST_URI']) ) ); - exit; +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 = '

' . sprintf(__('You can use categories to define sections of your site and group related posts. The default category is “Uncategorized” until you change it in your writing settings.'), 'options-writing.php') . '

'; + $help = '

' . sprintf(__( 'You can use categories to define sections of your site and group related posts. The default category is “Uncategorized” until you change it in your writing settings.' ) , 'options-writing.php' ) . '

'; + elseif ( 'link_category' == $taxonomy ) + $help = '

' . __( '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.' ) . '

'; else - $help = '

' . __('You can assign keywords to your posts using Post Tags. Unlike categories, tags have no hierarchy, meaning there’s no relationship from one tag to another.') . '

'; - - $help .='

' . __('What’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.') . '

'; + $help = '

' . __( 'You can assign keywords to your posts using tags. Unlike categories, tags have no hierarchy, meaning there’s no relationship from one tag to another.' ) . '

'; - if ( 'category' == $taxonomy ) - $help .= '

' . __('When adding a new category on this screen, you’ll fill in the following fields:') . '

'; + if ( 'link_category' == $taxonomy ) + $help .= '

' . __( 'You can delete Link Categories in the Bulk Action pull-down, but that action does not delete the links within the category. Instead, it moves them to the default Link Category.' ) . '

'; else - $help .= '

' . __('When adding a new tag on this screen, you’ll fill in the following fields:') . '

'; + $help .='

' . __( 'What’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.' ) . '

'; - $help .= '