WordPress.org

Make WordPress Core

Ticket #20871: 20871.4.diff

File 20871.4.diff, 12.2 KB (added by koopersmith, 6 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}