Allow attachments to be Detached from their parent in media grid and list modes.
See #6820. git-svn-id: https://develop.svn.wordpress.org/trunk@31619 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
26875b75a3
commit
6c8322e8fa
@ -2267,6 +2267,9 @@ function wp_ajax_save_attachment() {
|
|||||||
if ( 'attachment' != $post['post_type'] )
|
if ( 'attachment' != $post['post_type'] )
|
||||||
wp_send_json_error();
|
wp_send_json_error();
|
||||||
|
|
||||||
|
if ( isset( $changes['parent'] ) )
|
||||||
|
$post['post_parent'] = $changes['parent'];
|
||||||
|
|
||||||
if ( isset( $changes['title'] ) )
|
if ( isset( $changes['title'] ) )
|
||||||
$post['post_title'] = $changes['title'];
|
$post['post_title'] = $changes['title'];
|
||||||
|
|
||||||
|
@ -139,6 +139,9 @@ class WP_Media_List_Table extends WP_List_Table {
|
|||||||
if ( isset( $_REQUEST['found_post_id'] ) && isset( $_REQUEST['media'] ) )
|
if ( isset( $_REQUEST['found_post_id'] ) && isset( $_REQUEST['media'] ) )
|
||||||
return 'attach';
|
return 'attach';
|
||||||
|
|
||||||
|
if ( isset( $_REQUEST['parent_post_id'] ) && isset( $_REQUEST['media'] ) )
|
||||||
|
return 'detach';
|
||||||
|
|
||||||
if ( isset( $_REQUEST['delete_all'] ) || isset( $_REQUEST['delete_all2'] ) )
|
if ( isset( $_REQUEST['delete_all'] ) || isset( $_REQUEST['delete_all2'] ) )
|
||||||
return 'delete_all';
|
return 'delete_all';
|
||||||
|
|
||||||
@ -406,7 +409,16 @@ foreach ( $columns as $column_name => $column_display_name ) {
|
|||||||
} else {
|
} else {
|
||||||
echo $title;
|
echo $title;
|
||||||
} ?></strong>,
|
} ?></strong>,
|
||||||
<?php echo get_the_time( __( 'Y/m/d' ) ); ?>
|
<?php echo get_the_time( __( 'Y/m/d' ) ); ?><br />
|
||||||
|
<?php
|
||||||
|
if ( $user_can_edit ):
|
||||||
|
$detach_url = add_query_arg( array(
|
||||||
|
'parent_post_id' => $post->post_parent,
|
||||||
|
'media[]' => $post->ID,
|
||||||
|
'_wpnonce' => wp_create_nonce( 'bulk-' . $this->_args['plural'] )
|
||||||
|
), 'upload.php' ); ?>
|
||||||
|
<a class="hide-if-no-js detach-from-parent" href="<?php echo $detach_url ?>"><?php _e( 'Detach' ); ?></a>
|
||||||
|
<?php endif; ?>
|
||||||
</td>
|
</td>
|
||||||
<?php
|
<?php
|
||||||
} else {
|
} else {
|
||||||
|
@ -3010,3 +3010,61 @@ function wp_read_audio_metadata( $file ) {
|
|||||||
|
|
||||||
return $metadata;
|
return $metadata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Encapsulate logic for Attach/Detach actions
|
||||||
|
*
|
||||||
|
* @since 4.2.0
|
||||||
|
*
|
||||||
|
* @global wpdb $wpdb
|
||||||
|
* @param int $parent_id
|
||||||
|
* @param string $action
|
||||||
|
*/
|
||||||
|
function wp_media_attach_action( $parent_id, $action = 'attach' ) {
|
||||||
|
global $wpdb;
|
||||||
|
|
||||||
|
if ( ! $parent_id ) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! current_user_can( 'edit_post', $parent_id ) ) {
|
||||||
|
wp_die( __( 'You are not allowed to edit this post.' ) );
|
||||||
|
}
|
||||||
|
$ids = array();
|
||||||
|
foreach ( (array) $_REQUEST['media'] as $att_id ) {
|
||||||
|
$att_id = (int) $att_id;
|
||||||
|
|
||||||
|
if ( ! current_user_can( 'edit_post', $att_id ) ) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
$ids[] = $att_id;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! empty( $ids ) ) {
|
||||||
|
$ids_string = implode( ',', $ids );
|
||||||
|
if ( 'attach' === $action ) {
|
||||||
|
$result = $wpdb->query( $wpdb->prepare( "UPDATE $wpdb->posts SET post_parent = %d WHERE post_type = 'attachment' AND ID IN ( $ids_string )", $parent_id ) );
|
||||||
|
} else {
|
||||||
|
$result = $wpdb->query( "UPDATE $wpdb->posts SET post_parent = 0 WHERE post_type = 'attachment' AND ID IN ( $ids_string )" );
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ( $ids as $att_id ) {
|
||||||
|
clean_attachment_cache( $att_id );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( isset( $result ) ) {
|
||||||
|
$location = 'upload.php';
|
||||||
|
if ( $referer = wp_get_referer() ) {
|
||||||
|
if ( false !== strpos( $referer, 'upload.php' ) ) {
|
||||||
|
$location = remove_query_arg( array( 'attached', 'detached' ), $referer );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$key = 'attach' === $action ? 'attached' : 'detached';
|
||||||
|
$location = add_query_arg( array( $key => $result ), $location );
|
||||||
|
wp_redirect( $location );
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
}
|
@ -113,45 +113,14 @@ if ( $doaction ) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch ( $doaction ) {
|
switch ( $doaction ) {
|
||||||
case 'attach':
|
case 'detach':
|
||||||
$parent_id = (int) $_REQUEST['found_post_id'];
|
wp_media_attach_action( $_REQUEST['parent_post_id'], 'detach' );
|
||||||
if ( !$parent_id )
|
|
||||||
return;
|
|
||||||
|
|
||||||
$parent = get_post( $parent_id );
|
|
||||||
if ( !current_user_can( 'edit_post', $parent_id ) )
|
|
||||||
wp_die( __( 'You are not allowed to edit this post.' ) );
|
|
||||||
|
|
||||||
$attach = array();
|
|
||||||
foreach ( (array) $_REQUEST['media'] as $att_id ) {
|
|
||||||
$att_id = (int) $att_id;
|
|
||||||
|
|
||||||
if ( !current_user_can( 'edit_post', $att_id ) )
|
|
||||||
continue;
|
|
||||||
|
|
||||||
$attach[] = $att_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( ! empty( $attach ) ) {
|
|
||||||
$attach_string = implode( ',', $attach );
|
|
||||||
$attached = $wpdb->query( $wpdb->prepare( "UPDATE $wpdb->posts SET post_parent = %d WHERE post_type = 'attachment' AND ID IN ( $attach_string )", $parent_id ) );
|
|
||||||
foreach ( $attach as $att_id ) {
|
|
||||||
clean_attachment_cache( $att_id );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( isset( $attached ) ) {
|
|
||||||
$location = 'upload.php';
|
|
||||||
if ( $referer = wp_get_referer() ) {
|
|
||||||
if ( false !== strpos( $referer, 'upload.php' ) )
|
|
||||||
$location = $referer;
|
|
||||||
}
|
|
||||||
|
|
||||||
$location = add_query_arg( array( 'attached' => $attached ) , $location );
|
|
||||||
wp_redirect( $location );
|
|
||||||
exit;
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'attach':
|
||||||
|
wp_media_attach_action( $_REQUEST['found_post_id'] );
|
||||||
|
break;
|
||||||
|
|
||||||
case 'trash':
|
case 'trash':
|
||||||
if ( !isset( $post_ids ) )
|
if ( !isset( $post_ids ) )
|
||||||
break;
|
break;
|
||||||
@ -256,7 +225,12 @@ if ( ! empty( $_GET['posted'] ) ) {
|
|||||||
|
|
||||||
if ( ! empty( $_GET['attached'] ) && $attached = absint( $_GET['attached'] ) ) {
|
if ( ! empty( $_GET['attached'] ) && $attached = absint( $_GET['attached'] ) ) {
|
||||||
$message = sprintf( _n('Reattached %d attachment.', 'Reattached %d attachments.', $attached), $attached );
|
$message = sprintf( _n('Reattached %d attachment.', 'Reattached %d attachments.', $attached), $attached );
|
||||||
$_SERVER['REQUEST_URI'] = remove_query_arg(array('attached'), $_SERVER['REQUEST_URI']);
|
$_SERVER['REQUEST_URI'] = remove_query_arg( array( 'detached', 'attached' ), $_SERVER['REQUEST_URI'] );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( ! empty( $_GET['detached'] ) && $detached = absint( $_GET['detached'] ) ) {
|
||||||
|
$message = sprintf( _n( 'Detached %d attachment.', 'Detached %d attachments.', $detached ), $detached );
|
||||||
|
$_SERVER['REQUEST_URI'] = remove_query_arg( array( 'detached', 'attached' ), $_SERVER['REQUEST_URI'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( ! empty( $_GET['deleted'] ) && $deleted = absint( $_GET['deleted'] ) ) {
|
if ( ! empty( $_GET['deleted'] ) && $deleted = absint( $_GET['deleted'] ) ) {
|
||||||
|
@ -2656,6 +2656,7 @@ Attachment = View.extend({
|
|||||||
this.listenTo( this.model, 'change', this.render );
|
this.listenTo( this.model, 'change', this.render );
|
||||||
} else {
|
} else {
|
||||||
this.listenTo( this.model, 'change:percent', this.progress );
|
this.listenTo( this.model, 'change:percent', this.progress );
|
||||||
|
this.listenTo( this.model, 'change:parent', this.render );
|
||||||
}
|
}
|
||||||
this.listenTo( this.model, 'change:title', this._syncTitle );
|
this.listenTo( this.model, 'change:title', this._syncTitle );
|
||||||
this.listenTo( this.model, 'change:caption', this._syncCaption );
|
this.listenTo( this.model, 'change:caption', this._syncCaption );
|
||||||
@ -3195,7 +3196,8 @@ Details = Attachment.extend({
|
|||||||
'click .untrash-attachment': 'untrashAttachment',
|
'click .untrash-attachment': 'untrashAttachment',
|
||||||
'click .edit-attachment': 'editAttachment',
|
'click .edit-attachment': 'editAttachment',
|
||||||
'click .refresh-attachment': 'refreshAttachment',
|
'click .refresh-attachment': 'refreshAttachment',
|
||||||
'keydown': 'toggleSelectionHandler'
|
'keydown': 'toggleSelectionHandler',
|
||||||
|
'click .detach-from-parent': 'detachFromParent'
|
||||||
},
|
},
|
||||||
|
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
@ -3294,6 +3296,20 @@ Details = Attachment.extend({
|
|||||||
this.controller.trigger( 'attachment:keydown:arrow', event );
|
this.controller.trigger( 'attachment:keydown:arrow', event );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {Object} event
|
||||||
|
*/
|
||||||
|
detachFromParent: function( event ) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
this.model.save({
|
||||||
|
'parent' : 0,
|
||||||
|
'uploadedTo' : 0,
|
||||||
|
'uploadedToLink' : '',
|
||||||
|
'uploadedToTitle' : ''
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -52,6 +52,7 @@ Attachment = View.extend({
|
|||||||
this.listenTo( this.model, 'change', this.render );
|
this.listenTo( this.model, 'change', this.render );
|
||||||
} else {
|
} else {
|
||||||
this.listenTo( this.model, 'change:percent', this.progress );
|
this.listenTo( this.model, 'change:percent', this.progress );
|
||||||
|
this.listenTo( this.model, 'change:parent', this.render );
|
||||||
}
|
}
|
||||||
this.listenTo( this.model, 'change:title', this._syncTitle );
|
this.listenTo( this.model, 'change:title', this._syncTitle );
|
||||||
this.listenTo( this.model, 'change:caption', this._syncCaption );
|
this.listenTo( this.model, 'change:caption', this._syncCaption );
|
||||||
|
@ -35,7 +35,8 @@ Details = Attachment.extend({
|
|||||||
'click .untrash-attachment': 'untrashAttachment',
|
'click .untrash-attachment': 'untrashAttachment',
|
||||||
'click .edit-attachment': 'editAttachment',
|
'click .edit-attachment': 'editAttachment',
|
||||||
'click .refresh-attachment': 'refreshAttachment',
|
'click .refresh-attachment': 'refreshAttachment',
|
||||||
'keydown': 'toggleSelectionHandler'
|
'keydown': 'toggleSelectionHandler',
|
||||||
|
'click .detach-from-parent': 'detachFromParent'
|
||||||
},
|
},
|
||||||
|
|
||||||
initialize: function() {
|
initialize: function() {
|
||||||
@ -134,6 +135,20 @@ Details = Attachment.extend({
|
|||||||
this.controller.trigger( 'attachment:keydown:arrow', event );
|
this.controller.trigger( 'attachment:keydown:arrow', event );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {Object} event
|
||||||
|
*/
|
||||||
|
detachFromParent: function( event ) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
this.model.save({
|
||||||
|
'parent' : 0,
|
||||||
|
'uploadedTo' : 0,
|
||||||
|
'uploadedToLink' : '',
|
||||||
|
'uploadedToTitle' : ''
|
||||||
|
});
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -418,6 +418,9 @@ function wp_print_media_templates() {
|
|||||||
<# } else { #>
|
<# } else { #>
|
||||||
<span class="value">{{ data.uploadedToTitle }}</span>
|
<span class="value">{{ data.uploadedToTitle }}</span>
|
||||||
<# } #>
|
<# } #>
|
||||||
|
<# if ( data.nonces.edit ) { #>
|
||||||
|
<a class="detach-from-parent" data-id="{{ data.id }}" href="#">(<?php _e( 'Detach' ); ?>)</a>
|
||||||
|
<# } #>
|
||||||
</label>
|
</label>
|
||||||
<# } #>
|
<# } #>
|
||||||
<div class="attachment-compat"></div>
|
<div class="attachment-compat"></div>
|
||||||
|
Loading…
Reference in New Issue
Block a user