mirror of
https://github.com/WordPress/WordPress.git
synced 2024-11-05 02:10:45 +01:00
b8d6fd57e5
* XML-RPC: Improve error messages for unprivileged users. * External Libraries: Disable deserialization in Requests_Utility_FilteredIterator * Embeds: Disable embeds on deactivated Multisite sites. * Coding standards: Modify escaping functions to avoid potential false positives. * XML-RPC: Return error message if attachment ID is incorrect. * Upgrade/install: Improve logic check when determining installation status. * Meta: Sanitize meta key before checking protection status. * Themes: Ensure that only privileged users can set a background image when a theme is using the deprecated custom background page. Brings the changes from [49380,49382-49388] to the 4.3 branch. Props xknown, zieladam, peterwilsoncc, whyisjake, desrosj, dd32. Built from https://develop.svn.wordpress.org/branches/4.3@49403 git-svn-id: http://core.svn.wordpress.org/branches/4.3@49162 1a063a9b-81f0-0310-95a4-ce76da25c4cd
262 lines
6.9 KiB
PHP
262 lines
6.9 KiB
PHP
<?php
|
|
/**
|
|
* WordPress Administration Template Header
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
@header('Content-Type: ' . get_option('html_type') . '; charset=' . get_option('blog_charset'));
|
|
if ( ! defined( 'WP_ADMIN' ) )
|
|
require_once( dirname( __FILE__ ) . '/admin.php' );
|
|
|
|
/**
|
|
* In case admin-header.php is included in a function.
|
|
*
|
|
* @global string $title
|
|
* @global string $hook_suffix
|
|
* @global WP_Screen $current_screen
|
|
* @global WP_Locale $wp_locale
|
|
* @global string $pagenow
|
|
* @global string $wp_version
|
|
* @global string $update_title
|
|
* @global int $total_update_count
|
|
* @global string $parent_file
|
|
*/
|
|
global $title, $hook_suffix, $current_screen, $wp_locale, $pagenow, $wp_version,
|
|
$update_title, $total_update_count, $parent_file;
|
|
|
|
// Catch plugins that include admin-header.php before admin.php completes.
|
|
if ( empty( $current_screen ) )
|
|
set_current_screen();
|
|
|
|
get_admin_page_title();
|
|
$title = esc_html( strip_tags( $title ) );
|
|
|
|
if ( is_network_admin() )
|
|
$admin_title = sprintf( __( 'Network Admin: %s' ), esc_html( get_current_site()->site_name ) );
|
|
elseif ( is_user_admin() )
|
|
$admin_title = sprintf( __( 'User Dashboard: %s' ), esc_html( get_current_site()->site_name ) );
|
|
else
|
|
$admin_title = get_bloginfo( 'name' );
|
|
|
|
if ( $admin_title == $title )
|
|
$admin_title = sprintf( __( '%1$s — WordPress' ), $title );
|
|
else
|
|
$admin_title = sprintf( __( '%1$s ‹ %2$s — WordPress' ), $title, $admin_title );
|
|
|
|
/**
|
|
* Filter the title tag content for an admin page.
|
|
*
|
|
* @since 3.1.0
|
|
*
|
|
* @param string $admin_title The page title, with extra context added.
|
|
* @param string $title The original page title.
|
|
*/
|
|
$admin_title = apply_filters( 'admin_title', $admin_title, $title );
|
|
|
|
wp_user_settings();
|
|
|
|
_wp_admin_html_begin();
|
|
?>
|
|
<title><?php echo $admin_title; ?></title>
|
|
<?php
|
|
|
|
wp_enqueue_style( 'colors' );
|
|
wp_enqueue_style( 'ie' );
|
|
wp_enqueue_script('utils');
|
|
wp_enqueue_script( 'svg-painter' );
|
|
|
|
$admin_body_class = preg_replace('/[^a-z0-9_-]+/i', '-', $hook_suffix);
|
|
?>
|
|
<script type="text/javascript">
|
|
addLoadEvent = function(func){if(typeof jQuery!=='undefined')jQuery(document).ready(func);else if(typeof wpOnload!=='function'){wpOnload=func;}else{var oldonload=wpOnload;wpOnload=function(){oldonload();func();}}};
|
|
var ajaxurl = '<?php echo esc_js( admin_url( 'admin-ajax.php', 'relative' ) ); ?>',
|
|
pagenow = '<?php echo esc_js( $current_screen->id ); ?>',
|
|
typenow = '<?php echo esc_js( $current_screen->post_type ); ?>',
|
|
adminpage = '<?php echo esc_js( $admin_body_class ); ?>',
|
|
thousandsSeparator = '<?php echo esc_js( $wp_locale->number_format['thousands_sep'] ); ?>',
|
|
decimalPoint = '<?php echo esc_js( $wp_locale->number_format['decimal_point'] ); ?>',
|
|
isRtl = <?php echo (int) is_rtl(); ?>;
|
|
</script>
|
|
<meta name="viewport" content="width=device-width,initial-scale=1.0">
|
|
<?php
|
|
|
|
/**
|
|
* Enqueue scripts for all admin pages.
|
|
*
|
|
* @since 2.8.0
|
|
*
|
|
* @param string $hook_suffix The current admin page.
|
|
*/
|
|
do_action( 'admin_enqueue_scripts', $hook_suffix );
|
|
|
|
/**
|
|
* Fires when styles are printed for a specific admin page based on $hook_suffix.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( "admin_print_styles-$hook_suffix" );
|
|
|
|
/**
|
|
* Fires when styles are printed for all admin pages.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( 'admin_print_styles' );
|
|
|
|
/**
|
|
* Fires when scripts are printed for a specific admin page based on $hook_suffix.
|
|
*
|
|
* @since 2.1.0
|
|
*/
|
|
do_action( "admin_print_scripts-$hook_suffix" );
|
|
|
|
/**
|
|
* Fires when scripts are printed for all admin pages.
|
|
*
|
|
* @since 2.1.0
|
|
*/
|
|
do_action( 'admin_print_scripts' );
|
|
|
|
/**
|
|
* Fires in head section for a specific admin page.
|
|
*
|
|
* The dynamic portion of the hook, `$hook_suffix`, refers to the hook suffix
|
|
* for the admin page.
|
|
*
|
|
* @since 2.1.0
|
|
*/
|
|
do_action( "admin_head-$hook_suffix" );
|
|
|
|
/**
|
|
* Fires in head section for all admin pages.
|
|
*
|
|
* @since 2.1.0
|
|
*/
|
|
do_action( 'admin_head' );
|
|
|
|
if ( get_user_setting('mfold') == 'f' )
|
|
$admin_body_class .= ' folded';
|
|
|
|
if ( !get_user_setting('unfold') )
|
|
$admin_body_class .= ' auto-fold';
|
|
|
|
if ( is_admin_bar_showing() )
|
|
$admin_body_class .= ' admin-bar';
|
|
|
|
if ( is_rtl() )
|
|
$admin_body_class .= ' rtl';
|
|
|
|
if ( $current_screen->post_type )
|
|
$admin_body_class .= ' post-type-' . $current_screen->post_type;
|
|
|
|
if ( $current_screen->taxonomy )
|
|
$admin_body_class .= ' taxonomy-' . $current_screen->taxonomy;
|
|
|
|
$admin_body_class .= ' branch-' . str_replace( array( '.', ',' ), '-', floatval( $wp_version ) );
|
|
$admin_body_class .= ' version-' . str_replace( '.', '-', preg_replace( '/^([.0-9]+).*/', '$1', $wp_version ) );
|
|
$admin_body_class .= ' admin-color-' . sanitize_html_class( get_user_option( 'admin_color' ), 'fresh' );
|
|
$admin_body_class .= ' locale-' . sanitize_html_class( strtolower( str_replace( '_', '-', get_locale() ) ) );
|
|
|
|
if ( wp_is_mobile() )
|
|
$admin_body_class .= ' mobile';
|
|
|
|
if ( is_multisite() )
|
|
$admin_body_class .= ' multisite';
|
|
|
|
if ( is_network_admin() )
|
|
$admin_body_class .= ' network-admin';
|
|
|
|
$admin_body_class .= ' no-customize-support no-svg';
|
|
|
|
?>
|
|
</head>
|
|
<?php
|
|
/**
|
|
* Filter the CSS classes for the body tag in the admin.
|
|
*
|
|
* This filter differs from the {@see 'post_class'} and {@see 'body_class'} filters
|
|
* in two important ways:
|
|
*
|
|
* 1. `$classes` is a space-separated string of class names instead of an array.
|
|
* 2. Not all core admin classes are filterable, notably: wp-admin, wp-core-ui,
|
|
* and no-js cannot be removed.
|
|
*
|
|
* @since 2.3.0
|
|
*
|
|
* @param string $classes Space-separated list of CSS classes.
|
|
*/
|
|
$admin_body_classes = apply_filters( 'admin_body_class', '' );
|
|
?>
|
|
<body class="wp-admin wp-core-ui no-js <?php echo $admin_body_classes . ' ' . $admin_body_class; ?>">
|
|
<script type="text/javascript">
|
|
document.body.className = document.body.className.replace('no-js','js');
|
|
</script>
|
|
|
|
<?php
|
|
// Make sure the customize body classes are correct as early as possible.
|
|
if ( current_user_can( 'customize' ) ) {
|
|
wp_customize_support_script();
|
|
}
|
|
?>
|
|
|
|
<div id="wpwrap">
|
|
<?php require(ABSPATH . 'wp-admin/menu-header.php'); ?>
|
|
<div id="wpcontent">
|
|
|
|
<?php
|
|
/**
|
|
* Fires at the beginning of the content section in an admin page.
|
|
*
|
|
* @since 3.0.0
|
|
*/
|
|
do_action( 'in_admin_header' );
|
|
?>
|
|
|
|
<div id="wpbody" role="main">
|
|
<?php
|
|
unset($title_class, $blog_name, $total_update_count, $update_title);
|
|
|
|
$current_screen->set_parentage( $parent_file );
|
|
|
|
?>
|
|
|
|
<div id="wpbody-content" aria-label="<?php esc_attr_e('Main content'); ?>" tabindex="0">
|
|
<?php
|
|
|
|
$current_screen->render_screen_meta();
|
|
|
|
if ( is_network_admin() ) {
|
|
/**
|
|
* Print network admin screen notices.
|
|
*
|
|
* @since 3.1.0
|
|
*/
|
|
do_action( 'network_admin_notices' );
|
|
} elseif ( is_user_admin() ) {
|
|
/**
|
|
* Print user admin screen notices.
|
|
*
|
|
* @since 3.1.0
|
|
*/
|
|
do_action( 'user_admin_notices' );
|
|
} else {
|
|
/**
|
|
* Print admin screen notices.
|
|
*
|
|
* @since 3.1.0
|
|
*/
|
|
do_action( 'admin_notices' );
|
|
}
|
|
|
|
/**
|
|
* Print generic admin screen notices.
|
|
*
|
|
* @since 3.1.0
|
|
*/
|
|
do_action( 'all_admin_notices' );
|
|
|
|
if ( $parent_file == 'options-general.php' )
|
|
require(ABSPATH . 'wp-admin/options-head.php');
|