Make WordPress Core


Ignore:
Timestamp:
09/25/2023 05:04:41 PM (2 years ago)
Author:
spacedmonkey
Message:

Script Loader: Replace hardcoded output of style tags with calls to wp_add_inline_style.

In this commit, enhancements have been made by replacing manually constructed style tags with calls to wp_add_inline_style. Previously, numerous style tags were generated and output directly in the header, resulting in redundant code and bypassing the core's style enqueueing system. This approach made it challenging for third-party developers to manage and control the output of these style tags.

To ensure backward compatibility, the following functions have been deprecated and replaced:

  • print_embed_styles
  • print_emoji_styles
  • wp_admin_bar_header
  • _admin_bar_bump_cb

Backward compatibility shims have also been added, ensuring that if these functions were previously unhooked from there actions, they will continue to not output a style tag.

However, for the following functions, conversion to use inline styles was not feasible due to the potential disruption it might cause by changing the style tag IDs, potentially breaking JavaScript functionality for a number of plugins in the repository:

  • custom-background
  • wp-custom

These changes improve code maintainability and enhance the flexibility and control available to developers when managing style outputs within WordPress core.

Props spacedmonkey, hlunter, westonruter, flixos90.
Fixes #58775.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/formatting.php

    r56596 r56682  
    58595859
    58605860/**
    5861  * Prints the important emoji-related styles.
    5862  *
    5863  * @since 4.2.0
    5864  */
    5865 function print_emoji_styles() {
    5866     static $printed = false;
    5867 
    5868     if ( $printed ) {
     5861 * Enqueues the important emoji-related styles.
     5862 *
     5863 * @since 6.4.0
     5864 */
     5865function wp_enqueue_emoji_styles() {
     5866    // Back-compat for plugins that disable functionality by unhooking this action.
     5867    $action = is_admin() ? 'admin_print_styles' : 'wp_print_styles';
     5868    if ( ! has_action( $action, 'print_emoji_styles' ) ) {
    58695869        return;
    58705870    }
    5871 
    5872     $printed = true;
    5873 
    5874     $type_attr = current_theme_supports( 'html5', 'style' ) ? '' : ' type="text/css"';
    5875     ?>
    5876 <style<?php echo $type_attr; ?>>
    5877 img.wp-smiley,
    5878 img.emoji {
    5879     display: inline !important;
    5880     border: none !important;
    5881     box-shadow: none !important;
    5882     height: 1em !important;
    5883     width: 1em !important;
    5884     margin: 0 0.07em !important;
    5885     vertical-align: -0.1em !important;
    5886     background: none !important;
    5887     padding: 0 !important;
    5888 }
    5889 </style>
    5890     <?php
     5871    remove_action( $action, 'print_emoji_styles' );
     5872
     5873    $emoji_styles = '
     5874    img.wp-smiley, img.emoji {
     5875        display: inline !important;
     5876        border: none !important;
     5877        box-shadow: none !important;
     5878        height: 1em !important;
     5879        width: 1em !important;
     5880        margin: 0 0.07em !important;
     5881        vertical-align: -0.1em !important;
     5882        background: none !important;
     5883        padding: 0 !important;
     5884    }';
     5885    $handle       = 'wp-emoji-styles';
     5886    wp_register_style( $handle, false );
     5887    wp_add_inline_style( $handle, $emoji_styles );
     5888    wp_enqueue_style( $handle );
    58915889}
    58925890
Note: See TracChangeset for help on using the changeset viewer.