Index: wp-admin/edit.php
===================================================================
--- wp-admin/edit.php (revision 23485)
+++ wp-admin/edit.php (working copy)
@@ -145,6 +145,7 @@
$wp_list_table->prepare_items();
wp_enqueue_script('inline-edit-post');
+wp_enqueue_script('edit-post');
$title = $post_type_object->labels->name;
Index: wp-admin/includes/class-wp-posts-list-table.php
===================================================================
--- wp-admin/includes/class-wp-posts-list-table.php (revision 23485)
+++ wp-admin/includes/class-wp-posts-list-table.php (working copy)
@@ -555,7 +555,7 @@
if ( $lock_holder && $can_edit_post && $post->post_status != 'trash' ) {
printf( '%s',
- esc_html( sprintf( __( '%s is currently editing' ), $lock_holder->display_name ) ) );
+ esc_html( sprintf( __( '%s is currently editing' ), $lock_holder->display_name ) ) );
}
if ( ! $this->hierarchical_display && 'excerpt' == $mode && current_user_can( 'read_post', $post->ID ) )
Index: wp-admin/includes/misc.php
===================================================================
--- wp-admin/includes/misc.php (revision 23485)
+++ wp-admin/includes/misc.php (working copy)
@@ -561,3 +561,24 @@
}
}
add_action('admin_head', '_ipad_meta');
+
+function wp_check_locked_posts( $response, $data ) {
+ $checked = array();
+
+ if ( array_key_exists('wp-check-locked', $data) && is_array($data['wp-check-locked']) ) {
+ foreach ( $data['wp-check-locked'] as $key ) {
+ $post_id = (int) substr( $key, 5 );
+
+ if ( current_user_can( 'edit_post', $post_id ) && ( $user_id = wp_check_post_lock( $post_id ) ) ) {
+ if ( $user = get_userdata($user_id) )
+ $checked[$key] = sprintf( __( '%s is currently editing' ), $user->display_name );
+ }
+ }
+ }
+
+ if ( !empty($checked) )
+ $response['wp-check-locked'] = $checked;
+
+ return $response;
+}
+add_filter( 'heartbeat_received', 'wp_check_locked_posts', 10, 2 );
Index: wp-admin/js/edit-post.js
===================================================================
--- wp-admin/js/edit-post.js (revision 0)
+++ wp-admin/js/edit-post.js (working copy)
@@ -0,0 +1,25 @@
+(function($){
+ $( document ).on( 'heartbeat-tick.wp-check-locked', function( e, data ) {
+ var locked = data['wp-check-locked'] || {};
+
+ $('#the-list tr').each( function(i, el) {
+ var key = el.id, row = $(el);
+
+ if ( locked.hasOwnProperty( key ) ) {
+ if ( ! row.hasClass('wp-locked') )
+ row.addClass('wp-locked').find('.column-title strong').after( $('').text(locked[key]) );
+ row.find('.check-column checkbox').prop('checked', false);
+ } else if ( row.hasClass('wp-locked') ) {
+ row.removeClass('wp-locked').find('.column-title span.lock-holder').remove();
+ }
+ });
+ }).on( 'heartbeat-send.wp-check-locked', function( e, data ) {
+ var check = [];
+
+ $('#the-list tr').each( function(i, el) {
+ check.push( el.id );
+ });
+
+ data['wp-check-locked'] = check;
+ });
+}(jQuery));
Index: wp-admin/js/edit-post.js
===================================================================
--- wp-admin/js/edit-post.js (revision 0)
+++ wp-admin/js/edit-post.js (working copy)
Property changes on: wp-admin/js/edit-post.js
___________________________________________________________________
Added: svn:eol-style
## -0,0 +1 ##
+native
\ No newline at end of property
Index: wp-includes/script-loader.php
===================================================================
--- wp-includes/script-loader.php (revision 23485)
+++ wp-includes/script-loader.php (working copy)
@@ -416,6 +416,8 @@
// @todo: Core no longer uses theme-preview.js. Remove?
$scripts->add( 'theme-preview', "/wp-admin/js/theme-preview$suffix.js", array( 'thickbox', 'jquery' ), false, 1 );
+ $scripts->add( 'edit-post', "/wp-admin/js/edit-post$suffix.js", array( 'heartbeat' ), false, 1 );
+
$scripts->add( 'inline-edit-post', "/wp-admin/js/inline-edit-post$suffix.js", array( 'jquery', 'suggest' ), false, 1 );
did_action( 'init' ) && $scripts->localize( 'inline-edit-post', 'inlineEditL10n', array(
'error' => __('Error while saving the changes.'),