mirror of
https://github.com/gosticks/wordpress-develop.git
synced 2026-04-06 21:54:28 +00:00
Customize: Introduce WP_Customize_Manager::trash_changeset_post() to reduce duplication and ensure proper changeset trashing logic.
Trashing a changeset via `wp_trash_post()` does not have the desired result since it mutates `post_content` (via Kses) and the `post_name` (even though it is a UUID). Props dlh. See #39896, #42030. Fixes #42175. git-svn-id: https://develop.svn.wordpress.org/trunk@41824 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
@@ -2909,47 +2909,7 @@ function _wp_customize_publish_changeset( $new_status, $old_status, $changeset_p
|
||||
* and thus garbage collected.
|
||||
*/
|
||||
if ( ! wp_revisions_enabled( $changeset_post ) ) {
|
||||
$post = $changeset_post;
|
||||
$post_id = $changeset_post->ID;
|
||||
|
||||
/*
|
||||
* The following re-formulates the logic from wp_trash_post() as done in
|
||||
* wp_publish_post(). The reason for bypassing wp_trash_post() is that it
|
||||
* will mutate the post_content and the post_name when they should be
|
||||
* untouched.
|
||||
*/
|
||||
if ( ! EMPTY_TRASH_DAYS ) {
|
||||
wp_delete_post( $post_id, true );
|
||||
} else {
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( 'wp_trash_post', $post_id );
|
||||
|
||||
add_post_meta( $post_id, '_wp_trash_meta_status', $post->post_status );
|
||||
add_post_meta( $post_id, '_wp_trash_meta_time', time() );
|
||||
|
||||
$old_status = $post->post_status;
|
||||
$new_status = 'trash';
|
||||
$wpdb->update( $wpdb->posts, array( 'post_status' => $new_status ), array( 'ID' => $post->ID ) );
|
||||
clean_post_cache( $post->ID );
|
||||
|
||||
$post->post_status = $new_status;
|
||||
wp_transition_post_status( $new_status, $old_status, $post );
|
||||
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( 'edit_post', $post->ID, $post );
|
||||
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( "save_post_{$post->post_type}", $post->ID, $post, true );
|
||||
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( 'save_post', $post->ID, $post, true );
|
||||
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( 'wp_insert_post', $post->ID, $post, true );
|
||||
|
||||
/** This action is documented in wp-includes/post.php */
|
||||
do_action( 'trashed_post', $post_id );
|
||||
}
|
||||
$wp_customize->trash_changeset_post( $changeset_post->ID );
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user