WordPress.org

Make WordPress Core

Ticket #12922: 12922.6.diff

File 12922.6.diff, 6.9 KB (added by flixos90, 3 years ago)
  • src/wp-admin/admin-ajax.php

     
    6262        'send-attachment-to-editor', 'save-attachment-order', 'heartbeat', 'get-revision-diffs',
    6363        'save-user-color-scheme', 'update-widget', 'query-themes', 'parse-embed', 'set-attachment-thumbnail',
    6464        'parse-media-shortcode', 'destroy-sessions', 'install-plugin', 'update-plugin', 'press-this-save-post',
    65         'press-this-add-category', 'crop-image', 'generate-password', 'save-wporg-username', 'delete-plugin',
    66         'search-plugins', 'search-install-plugins', 'activate-plugin', 'update-theme', 'delete-theme',
    67         'install-theme', 'test_url',
     65        'press-this-add-category', 'crop-image', 'generate-password', 'save-wporg-username',
     66        'get-post-thumbnail-html', 'delete-plugin', 'search-plugins', 'search-install-plugins', 'activate-plugin',
     67        'update-theme', 'delete-theme', 'install-theme', 'test_url',
    6868);
    6969
    7070// Deprecated
  • src/wp-admin/includes/ajax-actions.php

     
    21642164}
    21652165
    21662166/**
     2167 * Ajax handler for retrieving HTML for the featured image.
     2168 *
     2169 * @since 4.6.0
     2170 */
     2171function wp_ajax_get_post_thumbnail_html() {
     2172        $post_ID = intval( $_POST['post_id'] );
     2173
     2174        check_ajax_referer( "update-post_$post_ID" );
     2175
     2176        if ( ! current_user_can( 'edit_post', $post_ID ) ) {
     2177                wp_die( -1 );
     2178        }
     2179
     2180        $thumbnail_id = intval( $_POST['thumbnail_id'] );
     2181
     2182        // For backwards compatibility, -1 refers to no featured image.
     2183        if ( -1 === $thumbnail_id ) {
     2184                $thumbnail_id = null;
     2185        }
     2186
     2187        $return = _wp_post_thumbnail_html( $thumbnail_id, $post_ID );
     2188        wp_send_json_success( $return );
     2189}
     2190
     2191/**
    21672192 * Ajax handler for setting the featured image for an attachment.
    21682193 *
    21692194 * @since 4.0.0
  • src/wp-admin/includes/post.php

     
    14281428                                $thumbnail_html
    14291429                        );
    14301430                        $content .= '<p class="hide-if-no-js howto" id="set-post-thumbnail-desc">' . __( 'Click the image to edit or update' ) . '</p>';
    1431                         $content .= '<p class="hide-if-no-js"><a href="#" id="remove-post-thumbnail" onclick="WPRemoveThumbnail(\'' . $ajax_nonce . '\');return false;">' . esc_html( $post_type_object->labels->remove_featured_image ) . '</a></p>';
     1431                        $content .= '<p class="hide-if-no-js"><a href="#" id="remove-post-thumbnail">' . esc_html( $post_type_object->labels->remove_featured_image ) . '</a></p>';
    14321432                }
    14331433        }
    14341434
     1435        $content .= '<input type="hidden" id="_thumbnail_id" name="_thumbnail_id" value="' . esc_attr( $thumbnail_id ? $thumbnail_id : '-1' ) . '" />';
     1436
    14351437        /**
    14361438         * Filters the admin post thumbnail HTML markup to return.
    14371439         *
     
    17531755                $query_args['preview_id'] = $post->ID;
    17541756                $query_args['preview_nonce'] = wp_create_nonce( 'post_preview_' . $post->ID );
    17551757
    1756                 if ( isset( $_POST['post_format'] ) )
     1758                if ( isset( $_POST['post_format'] ) ) {
    17571759                        $query_args['post_format'] = empty( $_POST['post_format'] ) ? 'standard' : sanitize_key( $_POST['post_format'] );
     1760                }
     1761
     1762                if ( isset( $_POST['_thumbnail_id'] ) ) {
     1763                        $query_args['_thumbnail_id'] = ( 0 >= intval( $_POST['_thumbnail_id'] ) ) ? '-1' : intval( $_POST['_thumbnail_id'] );
     1764                }
    17581765        }
    17591766
    17601767        return get_preview_post_link( $post, $query_args );
  • src/wp-includes/js/media-editor.js

     
    649649
    650650                        settings.post.featuredImageId = id;
    651651
    652                         wp.media.post( 'set-post-thumbnail', {
    653                                 json:         true,
     652                        wp.media.post( 'get-post-thumbnail-html', {
    654653                                post_id:      settings.post.id,
    655654                                thumbnail_id: settings.post.featuredImageId,
    656655                                _wpnonce:     settings.post.nonce
    657656                        }).done( function( html ) {
     657                                if ( html == '0' ) {
     658                                        window.alert( window.setPostThumbnailL10n.error );
     659                                        return;
     660                                }
    658661                                $( '.inside', '#postimagediv' ).html( html );
    659662                        });
    660663                },
    661664                /**
     665                 * Remove the featured image id, save the post thumbnail data and
     666                 * set the HTML in the post meta box to no featured image.
     667                 */
     668                remove: function() {
     669                        wp.media.featuredImage.set( -1 );
     670                },
     671                /**
    662672                 * The Featured Image workflow
    663673                 *
    664674                 * @global wp.media.controller.FeaturedImage
     
    735745
    736746                                wp.media.featuredImage.frame().open();
    737747                        }).on( 'click', '#remove-post-thumbnail', function() {
    738                                 wp.media.view.settings.post.featuredImageId = -1;
     748                                wp.media.featuredImage.remove();
     749                                return false;
    739750                        });
    740751                }
    741752        };
  • src/wp-includes/post.php

     
    32603260                }
    32613261        }
    32623262
     3263        if ( isset( $postarr['_thumbnail_id'] ) && ( post_type_supports( $post_type, 'thumbnail' ) || 'revision' === $post_type ) ) {
     3264                $thumbnail_id = intval( $postarr['_thumbnail_id'] );
     3265                if ( -1 === $thumbnail_id ) {
     3266                        delete_post_thumbnail( $post_ID );
     3267                } else {
     3268                        set_post_thumbnail( $post_ID, $thumbnail_id );
     3269                }
     3270        }
     3271
    32633272        if ( ! empty( $postarr['meta_input'] ) ) {
    32643273                foreach ( $postarr['meta_input'] as $field => $value ) {
    32653274                        update_post_meta( $post_ID, $field, $value );
  • src/wp-includes/revision.php

     
    530530        $post->post_excerpt = $preview->post_excerpt;
    531531
    532532        add_filter( 'get_the_terms', '_wp_preview_terms_filter', 10, 3 );
     533        add_filter( 'get_post_metadata', '_wp_preview_post_thumbnail_filter', 10, 4 );
    533534
    534535        return $post;
    535536}
     
    578579}
    579580
    580581/**
     582 * Filters post thumbnail lookup to set the post thumbnail.
     583 *
     584 * @since 4.6.0
     585 * @access private
     586 *
     587 * @param null|array|string $value     The value to return - a single metadata value, or an array of values.
     588 * @param int               $post_id   Post ID.
     589 * @param string            $meta_key  Meta key.
     590 * @param bool              $single    Whether to return only the first value of the specified $meta_key.
     591 * @return null|array The default return value or the post thumbnail meta array.
     592 */
     593function _wp_preview_post_thumbnail_filter( $value, $post_id, $meta_key, $single ) {
     594        if ( ! $post = get_post() ) {
     595                return $value;
     596        }
     597
     598        if ( empty( $_REQUEST['_thumbnail_id'] ) || $post->ID != $post_id || '_thumbnail_id' != $meta_key || 'revision' == $post->post_type ) {
     599                return $value;
     600        }
     601
     602        $thumbnail_id = intval( $_REQUEST['_thumbnail_id'] );
     603        if ( 0 >= $thumbnail_id ) {
     604                return '';
     605        }
     606
     607        return strval( $thumbnail_id );
     608}
     609
     610/**
    581611 * Gets the post revision version.
    582612 *
    583613 * @since 3.6.0