2016-01-15 03:27:27 -05:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Edit Term Administration Screen.
|
|
|
|
*
|
2016-02-06 21:43:26 -05:00
|
|
|
* @package WordPress
|
2016-01-15 03:27:27 -05:00
|
|
|
* @subpackage Administration
|
2016-02-06 21:43:26 -05:00
|
|
|
* @since 4.5.0
|
2016-01-15 03:27:27 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
/** WordPress Administration Bootstrap */
|
|
|
|
require_once( dirname( __FILE__ ) . '/admin.php' );
|
|
|
|
|
2016-03-07 07:56:28 -05:00
|
|
|
if ( empty( $_REQUEST['tag_ID'] ) ) {
|
2016-01-15 03:27:27 -05:00
|
|
|
$sendback = admin_url( 'edit-tags.php' );
|
|
|
|
if ( ! empty( $taxnow ) ) {
|
|
|
|
$sendback = add_query_arg( array( 'taxonomy' => $taxnow ), $sendback );
|
|
|
|
}
|
|
|
|
wp_redirect( esc_url( $sendback ) );
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
2016-03-11 03:52:29 -05:00
|
|
|
$tag_ID = absint( $_REQUEST['tag_ID'] );
|
2016-07-16 14:37:30 -04:00
|
|
|
$tag = get_term( $tag_ID, $taxnow, OBJECT, 'edit' );
|
2016-01-15 03:27:27 -05:00
|
|
|
|
|
|
|
if ( ! $tag instanceof WP_Term ) {
|
|
|
|
wp_die( __( 'You attempted to edit an item that doesn’t exist. Perhaps it was deleted?' ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
$tax = get_taxonomy( $tag->taxonomy );
|
|
|
|
$taxonomy = $tax->name;
|
|
|
|
$title = $tax->labels->edit_item;
|
|
|
|
|
|
|
|
if ( ! in_array( $taxonomy, get_taxonomies( array( 'show_ui' => true ) ) ) ||
|
2017-11-26 18:57:55 -05:00
|
|
|
! current_user_can( 'edit_term', $tag->term_id ) ) {
|
|
|
|
|
2016-01-15 03:27:27 -05:00
|
|
|
wp_die(
|
|
|
|
'<h1>' . __( 'Cheatin’ uh?' ) . '</h1>' .
|
Taxonomy: Introduce more fine grained capabilities for managing taxonomy terms.
This introduces the singular `edit_term`, `delete_term`, and `assign_term` meta capabilities for terms, and switches the base capability name for tags from `manage_categories` to `manage_post_tags` and the corresponding `edit_post_tags`, `delete_post_tags`, and `assign_post_tags`.
All of these capabilities ultimately map to `manage_categories` so by default there is no change in the behaviour of the capabilities for categories, tags, or custom taxonomies. The `map_meta_cap` filter and the `capabilities` argument when registering a taxonomy now allow for control over editing, deleting, and assigning individual terms, as well as a separation of capabilities for tags from those of categories.
Fixes #35614
Props johnjamesjacoby for feedback
Built from https://develop.svn.wordpress.org/trunk@38698
git-svn-id: http://core.svn.wordpress.org/trunk@38641 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2016-09-30 18:40:28 -04:00
|
|
|
'<p>' . __( 'Sorry, you are not allowed to edit this item.' ) . '</p>',
|
2016-01-15 03:27:27 -05:00
|
|
|
403
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$post_type = get_current_screen()->post_type;
|
|
|
|
|
|
|
|
// Default to the first object_type associated with the taxonomy if no post type was passed.
|
|
|
|
if ( empty( $post_type ) ) {
|
|
|
|
$post_type = reset( $tax->object_type );
|
|
|
|
}
|
|
|
|
|
|
|
|
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";
|
|
|
|
} elseif ( 'link_category' == $taxonomy ) {
|
|
|
|
$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";
|
|
|
|
}
|
|
|
|
|
2017-11-30 18:11:00 -05:00
|
|
|
get_current_screen()->set_screen_reader_content(
|
|
|
|
array(
|
|
|
|
'heading_pagination' => $tax->labels->items_list_navigation,
|
|
|
|
'heading_list' => $tax->labels->items_list,
|
|
|
|
)
|
|
|
|
);
|
2017-05-12 15:26:41 -04:00
|
|
|
wp_enqueue_script( 'admin-tags' );
|
2016-01-15 03:27:27 -05:00
|
|
|
require_once( ABSPATH . 'wp-admin/admin-header.php' );
|
|
|
|
include( ABSPATH . 'wp-admin/edit-tag-form.php' );
|
|
|
|
include( ABSPATH . 'wp-admin/admin-footer.php' );
|