WordPress.org

Make WordPress Core

Ticket #20871: 20871.4.diff

File 20871.4.diff, 12.2 KB (added by koopersmith, 3 years ago)
  • wp-admin/custom-header.php

     
    211211 
    212212                if ( isset( $_POST['resetheader'] ) ) { 
    213213                        check_admin_referer( 'custom-header-options', '_wpnonce-custom-header-options' ); 
    214                         $this->process_default_headers(); 
    215                         $default = get_theme_support( 'custom-header', 'default-image' ); 
    216                         $default = sprintf( $default, get_template_directory_uri(), get_stylesheet_directory_uri() ); 
    217                         foreach ( $this->default_headers as $header => $details ) { 
    218                                 if ( $details['url'] == $default ) { 
    219                                         $default_data = $details; 
    220                                         break; 
    221                                 } 
    222                         } 
    223                         set_theme_mod( 'header_image', $default ); 
    224                         if ( empty( $default_data['width'] ) ) 
    225                                 $default_data['width'] = get_theme_support( 'custom-header', 'width' ); 
    226                         if ( empty( $default_data['height'] ) ) 
    227                                 $default_data['height'] = get_theme_support( 'custom-header', 'height' ); 
    228                         set_theme_mod( 'header_image_data', (object) $default_data ); 
     214                        $this->reset_header_image(); 
    229215                        return; 
    230216                } 
    231217 
     
    237223 
    238224                if ( isset( $_POST['removeheader'] ) ) { 
    239225                        check_admin_referer( 'custom-header-options', '_wpnonce-custom-header-options' ); 
    240                         set_theme_mod( 'header_image', 'remove-header' ); 
     226                        $this->remove_header_image(); 
    241227                        return; 
    242228                } 
    243229 
     
    256242 
    257243                if ( isset( $_POST['default-header'] ) ) { 
    258244                        check_admin_referer( 'custom-header-options', '_wpnonce-custom-header-options' ); 
    259                         if ( 'random-default-image' == $_POST['default-header'] ) { 
    260                                 set_theme_mod( 'header_image', 'random-default-image' ); 
    261                         } elseif ( 'random-uploaded-image' == $_POST['default-header'] ) { 
    262                                 set_theme_mod( 'header_image', 'random-uploaded-image' ); 
    263                         } else { 
    264                                 $this->process_default_headers(); 
    265                                 $uploaded = get_uploaded_header_images(); 
    266                                 if ( isset( $uploaded[$_POST['default-header']] ) ) { 
    267                                         set_theme_mod( 'header_image', esc_url( $uploaded[$_POST['default-header']]['url'] ) ); 
    268                                         set_theme_mod( 'header_image_data', (object) $uploaded[$_POST['default-header']] ); 
    269                                 } elseif ( isset( $this->default_headers[$_POST['default-header']] ) ) { 
    270                                         set_theme_mod( 'header_image', esc_url( $this->default_headers[$_POST['default-header']]['url'] ) ); 
    271                                         if ( empty( $this->default_headers[$_POST['default-header']]['width'] ) ) 
    272                                                 $this->default_headers[$_POST['default-header']]['width'] = get_theme_support( 'custom-header', 'width' ); 
    273                                         if ( empty( $this->default_headers[$_POST['default-header']]['height'] ) ) 
    274                                                 $this->default_headers[$_POST['default-header']]['height'] = get_theme_support( 'custom-header', 'height' ); 
    275                                         set_theme_mod( 'header_image_data', (object) $this->default_headers[$_POST['default-header']] ); 
    276                                 } 
    277                         } 
     245                        $this->set_header_image( $_POST['default-header'] ); 
     246                        return; 
    278247                } 
    279248        } 
    280249 
     
    718687                        wp_die( __( 'Cheatin’ uh?' ) ); 
    719688 
    720689                if ( empty( $_POST ) && isset( $_GET['file'] ) ) { 
    721                         $id = absint( $_GET['file'] ); 
    722                         $file = get_attached_file( $id, true ); 
    723                         $url = wp_get_attachment_image_src( $id, 'full'); 
     690                        $attachment_id = absint( $_GET['file'] ); 
     691                        $file = get_attached_file( $attachment_id, true ); 
     692                        $url = wp_get_attachment_image_src( $attachment_id, 'full'); 
    724693                        $url = $url[0]; 
    725694                } elseif ( isset( $_POST ) ) { 
    726695                        extract($this->step_2_manage_upload()); 
     
    729698                if ( file_exists( $file ) ) { 
    730699                        list( $width, $height, $type, $attr ) = getimagesize( $file ); 
    731700                } else { 
    732                         $data = wp_get_attachment_metadata( $id ); 
     701                        $data = wp_get_attachment_metadata( $attachment_id ); 
    733702                        $height = $data[ 'height' ]; 
    734703                        $width = $data[ 'width' ]; 
    735704                        unset( $data ); 
     
    750719                { 
    751720                        // Add the meta-data 
    752721                        if ( file_exists( $file ) ) 
    753                                 wp_update_attachment_metadata( $id, wp_generate_attachment_metadata( $id, $file ) ); 
    754                         update_post_meta( $id, '_wp_attachment_is_custom_header', get_option('stylesheet' ) ); 
     722                                wp_update_attachment_metadata( $attachment_id, wp_generate_attachment_metadata( $attachment_id, $file ) ); 
    755723 
    756                         set_theme_mod('header_image', esc_url($url)); 
    757                         do_action('wp_create_file_in_uploads', $file, $id); // For replication 
     724                        $this->set_header_image( compact( 'url', 'attachment_id', 'width', 'height' ) ); 
     725 
     726                        do_action('wp_create_file_in_uploads', $file, $attachment_id); // For replication 
    758727                        return $this->finished(); 
    759728                } elseif ( $width > $max_width ) { 
    760729                        $oitar = $width / $max_width; 
    761                         $image = wp_crop_image($id, 0, 0, $width, $height, $max_width, $height / $oitar, false, str_replace(basename($file), 'midsize-'.basename($file), $file)); 
     730                        $image = wp_crop_image($attachment_id, 0, 0, $width, $height, $max_width, $height / $oitar, false, str_replace(basename($file), 'midsize-'.basename($file), $file)); 
    762731                        if ( ! $image || is_wp_error( $image ) ) 
    763732                                wp_die( __( 'Image could not be processed. Please go back and try again.' ), __( 'Image Processing Error' ) ); 
    764733 
    765                         $image = apply_filters('wp_create_file_in_uploads', $image, $id); // For replication 
     734                        $image = apply_filters('wp_create_file_in_uploads', $image, $attachment_id); // For replication 
    766735 
    767736                        $url = str_replace(basename($url), basename($image), $url); 
    768737                        $width = $width / $oitar; 
     
    788757        <input type="hidden" name="y1" id="y1" value="0"/> 
    789758        <input type="hidden" name="width" id="width" value="<?php echo esc_attr( $width ); ?>"/> 
    790759        <input type="hidden" name="height" id="height" value="<?php echo esc_attr( $height ); ?>"/> 
    791         <input type="hidden" name="attachment_id" id="attachment_id" value="<?php echo esc_attr( $id ); ?>" /> 
     760        <input type="hidden" name="attachment_id" id="attachment_id" value="<?php echo esc_attr( $attachment_id ); ?>" /> 
    792761        <input type="hidden" name="oitar" id="oitar" value="<?php echo esc_attr( $oitar ); ?>" /> 
    793762        <?php if ( empty( $_POST ) && isset( $_GET['file'] ) ) { ?> 
    794763        <input type="hidden" name="create-new-attachment" value="true" /> 
     
    835804                ); 
    836805 
    837806                // Save the data 
    838                 $id = wp_insert_attachment( $object, $file ); 
    839                 return compact( 'id', 'file', 'filename', 'url', 'type' ); 
     807                $attachment_id = wp_insert_attachment( $object, $file ); 
     808                return compact( 'attachment_id', 'file', 'filename', 'url', 'type' ); 
    840809        } 
    841810 
    842811        /** 
     
    918887                // Update the attachment 
    919888                $attachment_id = wp_insert_attachment( $object, $cropped ); 
    920889                wp_update_attachment_metadata( $attachment_id, wp_generate_attachment_metadata( $attachment_id, $cropped ) ); 
    921                 update_post_meta( $attachment_id, '_wp_attachment_is_custom_header', get_option( 'stylesheet' ) ); 
    922890 
    923                 set_theme_mod('header_image', $url); 
     891                $width = $dst_width; 
     892                $height = $dst_height; 
     893                $this->set_header_image( compact( 'url', 'attachment_id', 'width', 'height' ) ); 
    924894 
    925                 $header_data                = new stdClass(); 
    926                 $header_data->attachment_id = $attachment_id; 
    927                 $header_data->url           = $url; 
    928                 $header_data->thumbnail_url = $url; 
    929                 $header_data->width         = $dst_width; 
    930                 $header_data->height        = $dst_height; 
    931  
    932                 set_theme_mod( 'header_image_data', $header_data ); 
    933  
    934895                // cleanup 
    935896                $medium = str_replace( basename( $original ), 'midsize-' . basename( $original ), $original ); 
    936897                if ( file_exists( $medium ) ) 
     
    997958                return array( 'library' => __('Media Library') ); 
    998959        } 
    999960 
     961        /** 
     962         * Fetch header image data for a specific header image. 
     963         * 
     964         * @param string $choice Which header image to select. Allows for values of 'random-default-image', 
     965         *      for randomly cycling among the default images; 'random-uploaded-image', for randomly cycling 
     966         *      among the uploaded images; the key of a default image registered for that theme; and 
     967         *      the key of an image uploaded for that theme (the basename of the URL). 
     968         * 
     969         * @since 3.4.0 
     970         */ 
     971        final public function get_header_image_data( $choice ) { 
     972                if ( in_array( $choice, array( 'remove-header', 'random-default-image', 'random-uploaded-image' ) ) 
     973                        return null; 
     974 
     975                $uploaded = get_uploaded_header_images(); 
     976                if ( isset( $uploaded[ $choice ] ) ) 
     977                        return (object) $uploaded[ $choice ]; 
     978 
     979                $this->process_default_headers(); 
     980                if ( isset( $this->default_headers[ $choice ] ) ) 
     981                        return $this->default_headers[ $choice ]; 
     982 
     983                return null; 
     984        } 
     985 
     986        /** 
     987         * Choose a header image, selected from existing uploaded and default headers, 
     988         * or provide an array of uploaded header data (either new, or from media library). 
     989         * 
     990         * @param mixed $choice Which header image to select. Allows for values of 'random-default-image', 
     991         *      for randomly cycling among the default images; 'random-uploaded-image', for randomly cycling 
     992         *      among the uploaded images; the key of a default image registered for that theme; and 
     993         *      the key of an image uploaded for that theme (the basename of the URL). 
     994         *  Or an array of arguments: attachment_id, url, width, height. All are required. 
     995         * 
     996         * @since 3.4.0 
     997         */ 
     998        final public function set_header_image( $choice ) { 
     999                if ( is_array( $choice ) ) { 
     1000                        if ( ! isset( $choice['attachment_id'] ) || ! isset( $choice['url'] ) ) 
     1001                                return; 
     1002 
     1003                        $choice['url'] = esc_url_raw( $choice['url'] ); 
     1004 
     1005                        $header_image_data = (object) array( 
     1006                                'attachment_id' => $choice['attachment_id'], 
     1007                                'url'           => $choice['url'], 
     1008                                'thumbnail_url' => $choice['url'], 
     1009                                'height'        => $choice['height'], 
     1010                                'width'         => $choice['width'], 
     1011                        ); 
     1012 
     1013                        update_post_meta( $choice['attachment_id'], '_wp_attachment_is_custom_header', get_stylesheet() ); 
     1014                        set_theme_mod( 'header_image', $choice['url'] ); 
     1015                        set_theme_mod( 'header_image_data', $header_data_image ); 
     1016                        return; 
     1017                } 
     1018 
     1019                if ( in_array( $choice, array( 'remove-header', 'random-default-image', 'random-uploaded-image' ) ) { 
     1020                        set_theme_mod( 'header_image', $choice ); 
     1021                        remove_theme_mod( 'header_image_data' ); 
     1022                        return; 
     1023                } 
     1024 
     1025                if ( $header_image_data = $this->get_header_image_data( $choice ) ) { 
     1026                        set_theme_mod( 'header_image', esc_url_raw( $header_image_data['url'] ) ); 
     1027                        set_theme_mod( 'header_image_data', $header_image_data ); 
     1028                } 
     1029        } 
     1030 
     1031        /** 
     1032         * Remove a header image. 
     1033         * 
     1034         * @since 3.4.0 
     1035         */ 
     1036        final public function remove_header_image() { 
     1037                return $this->set_header_image( 'remove-header' ); 
     1038        } 
     1039 
     1040        /** 
     1041         * Reset a header image to the default image for the theme. 
     1042         * 
     1043         * This method does not do anything if the theme does not have a default header image. 
     1044         * 
     1045         * @since 3.4.0 
     1046         */ 
     1047        final public function reset_header_image() { 
     1048                $this->process_default_headers(); 
     1049                $default = get_theme_support( 'custom-header', 'default-image' ); 
     1050 
     1051                if ( ! $default ) 
     1052                        return $this->remove_header_image(); 
     1053 
     1054                $default = sprintf( $default, get_template_directory_uri(), get_stylesheet_directory_uri() ); 
     1055 
     1056                foreach ( $this->default_headers as $header => $details ) { 
     1057                        if ( $details['url'] == $default ) { 
     1058                                $default_data = $details; 
     1059                                break; 
     1060                        } 
     1061                } 
     1062 
     1063                set_theme_mod( 'header_image', $default ); 
     1064                set_theme_mod( 'header_image_data', (object) $default_data ); 
     1065        } 
    10001066} 
  • wp-admin/custom-background.php

     
    383383                wp_update_attachment_metadata( $id, wp_generate_attachment_metadata( $id, $file ) ); 
    384384                update_post_meta( $id, '_wp_attachment_is_custom_background', get_option('stylesheet' ) ); 
    385385 
    386                 set_theme_mod('background_image', esc_url($url)); 
     386                set_theme_mod('background_image', esc_url_raw($url)); 
    387387 
    388388                $thumbnail = wp_get_attachment_image_src( $id, 'thumbnail' ); 
    389                 set_theme_mod('background_image_thumb', esc_url( $thumbnail[0] ) ); 
     389                set_theme_mod('background_image_thumb', esc_url_raw( $thumbnail[0] ) ); 
    390390 
    391391                do_action('wp_create_file_in_uploads', $file, $id); // For replication 
    392392                $this->updated = true; 
     
    425425                update_post_meta( $attachment_id, '_wp_attachment_is_custom_background', get_option('stylesheet' ) ); 
    426426                $url = wp_get_attachment_image_src( $attachment_id, $size ); 
    427427                $thumbnail = wp_get_attachment_image_src( $attachment_id, 'thumbnail' ); 
    428                 set_theme_mod( 'background_image', esc_url( $url[0] ) ); 
    429                 set_theme_mod( 'background_image_thumb', esc_url( $thumbnail[0] ) ); 
     428                set_theme_mod( 'background_image', esc_url_raw( $url[0] ) ); 
     429                set_theme_mod( 'background_image_thumb', esc_url_raw( $thumbnail[0] ) ); 
    430430                exit; 
    431431        } 
    432432}