Sytling and improvements to inline editing, see #6815

git-svn-id: http://svn.automattic.com/wordpress/trunk@8943 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
azaozz 2008-09-21 19:45:45 +00:00
parent c57cfbaefc
commit 2e11a3bf66
10 changed files with 590 additions and 493 deletions

View File

@ -715,6 +715,7 @@ case 'hidden-columns' :
$current_user = wp_get_current_user(); $current_user = wp_get_current_user();
if ( is_array($hidden) ) if ( is_array($hidden) )
update_usermeta($current_user->ID, "manage-$page-columns-hidden", $hidden); update_usermeta($current_user->ID, "manage-$page-columns-hidden", $hidden);
break;
case 'get-permalink': case 'get-permalink':
check_ajax_referer( 'getpermalink', 'getpermalinknonce' ); check_ajax_referer( 'getpermalink', 'getpermalinknonce' );
$post_id = isset($_POST['post_id'])? intval($_POST['post_id']) : 0; $post_id = isset($_POST['post_id'])? intval($_POST['post_id']) : 0;
@ -727,16 +728,8 @@ case 'sample-permalink':
$slug = isset($_POST['new_slug'])? $_POST['new_slug'] : ''; $slug = isset($_POST['new_slug'])? $_POST['new_slug'] : '';
die(get_sample_permalink_html($post_id, $title, $slug)); die(get_sample_permalink_html($post_id, $title, $slug));
break; break;
case 'inline-data':
check_ajax_referer( 'inlineeditnonce', 'inline_edit_nonce' );
if ( isset($_POST['posts']) )
get_inline_data( explode(',', $_POST['posts']) );
die();
break;
case 'inline-save': case 'inline-save':
check_ajax_referer( 'inlineeditnonce', 'inline_edit_nonce' ); check_ajax_referer( 'inlineeditnonce', '_inline_edit' );
if ( ! isset($_POST['post_ID']) ) if ( ! isset($_POST['post_ID']) )
exit; exit;

View File

@ -806,7 +806,8 @@ table.diff .diff-addedline ins {
border-bottom-color: #14568A; border-bottom-color: #14568A;
} }
#replydiv { #replydiv,
.inline-editor .quick-edit-div {
border-color: #EBEBEB #CCC #CCC #EBEBEB; border-color: #EBEBEB #CCC #CCC #EBEBEB;
background-color: #fff; background-color: #fff;
} }
@ -821,7 +822,7 @@ table.diff .diff-addedline ins {
background-color: #f8f8f8; background-color: #f8f8f8;
} }
/* table vim shorcuts */ /* table vim shortcuts */
.vim-current { .vim-current {
background-color: #CFEBF7 !important; background-color: #CFEBF7 !important;
} }
@ -843,3 +844,26 @@ div.star.select:hover {
#plugin-information .fyi h2.mainheader { #plugin-information .fyi h2.mainheader {
background-color: #cee1ef; background-color: #cee1ef;
} }
/* inline editor */
.inline-editor input,
.inline-editor textarea {
border-color: #ddd;
}
.inline-editor div.title {
background-color: #CFEBF7;
}
.inline-editor ul.cat-checklist {
background-color: #FFFFFF;
}
.inline-editor .categories .catshow,
.inline-editor .categories .cathide {
color: #2583AD;
}
.inline-editor .quick-edit-save {
background-color: #CFEBF7;
}

View File

@ -789,7 +789,8 @@ table.diff .diff-addedline ins {
border-bottom-color: #E4F2FD; border-bottom-color: #E4F2FD;
} }
#replydiv { #replydiv,
.inline-editor .quick-edit-div {
border-color: #EBEBEB #CCC #CCC #EBEBEB; border-color: #EBEBEB #CCC #CCC #EBEBEB;
background-color: #fff; background-color: #fff;
} }
@ -804,7 +805,7 @@ table.diff .diff-addedline ins {
background-color: #f8f8f8; background-color: #f8f8f8;
} }
/* table vim shorcuts */ /* table vim shortcuts */
.vim-current { .vim-current {
background-color: #E4F2FD !important; background-color: #E4F2FD !important;
} }
@ -826,3 +827,26 @@ div.star.select:hover {
#plugin-information .fyi h2.mainheader { #plugin-information .fyi h2.mainheader {
background-color: #cee1ef; background-color: #cee1ef;
} }
/* inline editor */
.inline-editor input,
.inline-editor textarea {
border-color: #ddd;
}
.inline-editor div.title {
background-color: #EAF3FA;
}
.inline-editor ul.cat-checklist {
background-color: #FFFFFF;
}
.inline-editor .categories .catshow,
.inline-editor .categories .cathide {
color: #2583AD;
}
.inline-editor .quick-edit-save {
background-color: #EAF3FA;
}

View File

@ -189,7 +189,7 @@ $all = !( $h2_search || $post_status_q );
if ($posts) { if ($posts) {
?> ?>
<table class="widefat"> <table class="widefat page">
<thead> <thead>
<tr> <tr>
<?php print_column_headers('page'); ?> <?php print_column_headers('page'); ?>

View File

@ -8,7 +8,7 @@
if ( ! defined('ABSPATH') ) die(); if ( ! defined('ABSPATH') ) die();
?> ?>
<table class="widefat"> <table class="widefat post">
<thead> <thead>
<tr> <tr>
<?php print_column_headers('post'); ?> <?php print_column_headers('post'); ?>

View File

@ -185,7 +185,7 @@ if ( $page_links )
<div class="alignleft"> <div class="alignleft">
<select name="action"> <select name="action">
<option value="" selected><?php _e('Actions'); ?></option> <option value="" selected="selected"><?php _e('Actions'); ?></option>
<option value="edit"><?php _e('Edit'); ?></option> <option value="edit"><?php _e('Edit'); ?></option>
<option value="delete"><?php _e('Delete'); ?></option> <option value="delete"><?php _e('Delete'); ?></option>
</select> </select>

View File

@ -249,7 +249,7 @@ class Walker_Category_Checklist extends Walker {
extract($args); extract($args);
$class = in_array( $category->term_id, $popular_cats ) ? ' class="popular-category"' : ''; $class = in_array( $category->term_id, $popular_cats ) ? ' class="popular-category"' : '';
$output .= "\n<li id='category-$category->term_id'$class>" . '<label for="in-category-' . $category->term_id . '" class="selectit"><input value="' . $category->term_id . '" type="checkbox" name="post_category[]" id="in-category-' . $category->term_id . '"' . (in_array( $category->term_id, $selected_cats ) ? ' checked="checked"' : "" ) . '/> ' . wp_specialchars( apply_filters('the_category', $category->name )) . '</label>'; $output .= "\n<li id='category-$category->term_id'$class>" . '<label class="selectit"><input value="' . $category->term_id . '" type="checkbox" name="post_category[]" id="in-category-' . $category->term_id . '"' . (in_array( $category->term_id, $selected_cats ) ? ' checked="checked"' : "" ) . '/> ' . wp_specialchars( apply_filters('the_category', $category->name )) . '</label>';
} }
function end_el(&$output, $category, $depth, $args) { function end_el(&$output, $category, $depth, $args) {
@ -315,7 +315,7 @@ function wp_popular_terms_checklist( $taxonomy, $default = 0, $number = 10, $ech
?> ?>
<li id="<?php echo $id; ?>" class="popular-category"> <li id="<?php echo $id; ?>" class="popular-category">
<label class="selectit" for="in-<?php echo $id; ?>"> <label class="selectit">
<input id="in-<?php echo $id; ?>" type="checkbox" value="<?php echo (int) $category->term_id; ?>" /> <input id="in-<?php echo $id; ?>" type="checkbox" value="<?php echo (int) $category->term_id; ?>" />
<?php echo wp_specialchars( apply_filters( 'the_category', $category->name ) ); ?> <?php echo wp_specialchars( apply_filters( 'the_category', $category->name ) ); ?>
</label> </label>
@ -607,18 +607,24 @@ function print_column_headers( $type ) {
} }
function inline_edit_row( $type ) { function inline_edit_row( $type ) {
global $current_user; global $current_user, $mode;
if ( 'post' == $type ) $is_page = 'page' == $type;
$post = get_default_post_to_edit(); if ( $is_page )
else
$post = get_default_page_to_edit(); $post = get_default_page_to_edit();
else
$post = get_default_post_to_edit();
echo '<tr id="inline-edit" style="display: none">'; $columns = $is_page ? wp_manage_pages_columns() : wp_manage_posts_columns();
$columns = $type == 'post' ? wp_manage_posts_columns() : wp_manage_pages_columns();
$hidden = (array) get_user_option( "manage-$type-columns-hidden" ); $hidden = (array) get_user_option( "manage-$type-columns-hidden" );
$hidden_count = empty($hidden[0]) ? 0 : count($hidden);
$col_count = count($columns) - $hidden_count;
$m = ( isset($mode) && 'excerpt' == $mode ) ? 'excerpt' : 'list';
?>
<tr title="<?php _e('Double-click to cancel'); ?>" id="inline-edit" style="display: none"><td colspan="<?php echo $col_count; ?>">
<?php
foreach($columns as $column_name=>$column_display_name) { foreach($columns as $column_name=>$column_display_name) {
$class = "class=\"$column_name column-$column_name\""; $class = "class=\"$column_name column-$column_name quick-edit-div\"";
$style = ''; $style = '';
if ( in_array($column_name, $hidden) ) if ( in_array($column_name, $hidden) )
@ -627,152 +633,175 @@ function inline_edit_row( $type ) {
$attributes = "$class$style"; $attributes = "$class$style";
switch($column_name) { switch($column_name) {
case 'cb':
case 'cb': ?>
<th class="check-column"></th>
<?php
break; break;
case 'modified': case 'modified':
case 'date': case 'date':
$attributes = 'class="date column-date"' . $style;
?> ?>
<td class="date"<?php echo $style ?>> <div <?php echo $attributes; ?> title="<?php _e('Timestamp'); ?>">
<div class="title"><?php _e('Timestamp'); ?></div>
<div class="in">
<?php touch_time(1, 1, 4, 1); ?> <?php touch_time(1, 1, 4, 1); ?>
</td> </div>
</div>
<?php <?php
break; break;
case 'title': case 'title':
$attributes = "class=\"$type-title column-title\"" . $style; $attributes = "class=\"$type-title column-title quick-edit-div\"" . $style; ?>
?> <div <?php echo $attributes ?>>
<td <?php echo $attributes ?>> <div class="title"><?php _e('Title'); ?></div>
<?php wp_nonce_field( 'inlineeditnonce', 'inline_edit_nonce', false ) ?> <div class="in">
<div class="title"> <label title="<?php _e('Title'); ?>"><input type="text" name="post_title" class="ptitle" value="" /></label><br />
<input type="text" name="post_title" class="title" value="" /><br /> <div class="slug">
<label><?php _e('Slug'); ?></label><input type="text" name="post_name" value="" class="slug" /> <label title="<?php _e('Slug'); ?>"><?php _e('Slug'); ?><input type="text" name="post_name" value="" /></label></div>
</div> </div>
<?php if ($type == 'page'): ?> </div>
<div class="other"> <?php if ( $is_page ) { ?>
<label><?php _e('Parent'); ?></label> <div class="parent quick-edit-div" title="<?php _e('Page Parent'); ?>">
<div class="title"><?php _e('Page Parent'); ?></div>
<div class="in">
<select name="post_parent"> <select name="post_parent">
<option value="0"><?php _e('Main Page (no parent)'); ?></option> <option value="0"><?php _e('Main Page (no parent)'); ?></option>
<?php parent_dropdown(); ?> <?php parent_dropdown(); ?>
</select><br /> </select>
<label><?php _e('Template'); ?></label> </div>
</div>
<div class="template quick-edit-div" title="<?php _e('Page Template'); ?>">
<div class="title"><?php _e('Page Template'); ?></div>
<div class="in">
<select name="page_template"> <select name="page_template">
<option value='default'><?php _e('Default Template'); ?></option> <option value='default'><?php _e('Default Template'); ?></option>
<?php page_template_dropdown() ?> <?php page_template_dropdown() ?>
</select> </select>
</div> </div>
<div class="more">
<label><?php _e('Order'); ?></label><input type="text" name="menu_order" value="<?php echo $post->menu_order ?>" />
<label><?php _e('Password'); ?></label><input type="text" name="post_password" value="<?php echo $post->post_password ?>" />
</div> </div>
<?php endif; ?> <div class="order quick-edit-div" title="<?php _e('Page Order'); ?>">
<div class="clear"></div> <div class="title"><?php _e('Page Order'); ?></div>
<div class="save"> <div class="in">
<?php <input type="text" name="menu_order" value="<?php echo $post->menu_order ?>" />
$actions = array();
$actions['save'] = '<a href="#">' . __('Save') . '</a>';
$actions['cancel'] = '<a href="#">' . __('Cancel') . '</a>';
$action_count = count($actions);
$i = 0;
foreach ( $actions as $action => $link ) {
++$i;
( $i == $action_count ) ? $sep = '' : $sep = ' | ';
echo "<span class='$action'>$link$sep</span>";
}
?>
</div> </div>
</td> </div>
<?php <?php }
break; break;
case 'categories': ?> case 'categories': ?>
<td <?php echo $attributes ?>> <div <?php echo $attributes ?> title="<?php _e('Categories'); ?>">
<ul class="categories"> <div class="title"><?php _e('Categories'); ?>
<?php wp_category_checklist() ?> <span class="catshow"><?php _e('(expand)'); ?></span>
<span class="cathide" style="display:none;"><?php _e('(fold)'); ?></span></div>
<ul class="cat-checklist">
<?php wp_category_checklist(); ?>
</ul> </ul>
</td> </div>
<?php <?php
break; break;
case 'tags': ?> case 'tags': ?>
<td <?php echo $attributes ?>> <div <?php echo $attributes ?> title="<?php _e('Tags'); ?>">
<textarea name="tags_input"></textarea> <div class="title"><?php _e('Tags'); ?></div>
</td> <div class="in">
<textarea cols="22" rows="1" type="text" name="tags_input" class="tags_input"></textarea>
</div>
</div>
<?php <?php
break; break;
case 'comments': case 'comments':
$attributes = 'class="comments column-comments num"' . $style; $attributes = 'class="comments column-comments num quick-edit-div"' . $style; ?>
?> <div <?php echo $attributes ?> title="<?php _e('Comments and Pings'); ?>">
<td <?php echo $attributes ?>> <div class="title"><?php _e('Comments and Pings'); ?></div>
<input title="Allow Comments" type="checkbox" name="comment_status" value="open" /><br /> <div class="in">
<input title="Allow Pings" type="checkbox" name="ping_status" value="open" /> <label><input type="checkbox" name="comment_status" value="open" />
</td> <?php _e('Allow Comments'); ?></label><br />
<label><input type="checkbox" name="ping_status" value="open" />
<?php _e('Allow Pings'); ?></label>
</div>
</div>
<?php <?php
break; break;
case 'author': ?> case 'author':
<td <?php echo $attributes ?>>
<?php
$authors = get_editable_user_ids( $current_user->id ); // TODO: ROLE SYSTEM $authors = get_editable_user_ids( $current_user->id ); // TODO: ROLE SYSTEM
if ( $authors && count( $authors ) > 1 ) { if ( $authors && count( $authors ) > 1 ) { ?>
wp_dropdown_users( array('include' => $authors, 'name' => 'post_author', 'class'=> 'author', 'selected' => $post->post_author) ); <div <?php echo $attributes ?> title="<?php _e('Author'); ?>">
} else { <div class="title"><?php _e('Author'); ?></div>
echo $current_user->user_nicename.'<input type="hidden" value="'.$post->post_author.'" class="author" />'; <div class="in">
} <?php wp_dropdown_users( array('include' => $authors, 'name' => 'post_author', 'class'=> 'authors', 'selected' => $post->post_author) ); ?>
?> </div>
</td> </div>
<?php } ?>
<div class="password quick-edit-div" title="<?php _e('Password'); ?>">
<div class="title"><?php _e('Password'); ?></div>
<div class="in">
<input type="text" name="post_password" value="<?php echo $post->post_password ?>" />
<label title="<?php _e('Privacy'); ?>">
<input type="checkbox" name="keep_private" value="private" <?php checked($post->post_status, 'private'); ?> /> <?php echo $is_page ? __('Keep this page private') : __('Keep this post private'); ?></label>
</div>
</div>
<?php <?php
break; break;
case 'status': ?> case 'status': ?>
<td <?php echo $attributes ?>> <div <?php echo $attributes ?> title="<?php _e('Status'); ?>">
<div class="title"><?php _e('Status'); ?></div>
<div class="in">
<select name="post_status"> <select name="post_status">
<?php if ( current_user_can('publish_posts') ) : // Contributors only get "Unpublished" and "Pending Review" ?> <?php if ( current_user_can('publish_posts') ) { // Contributors only get "Unpublished" and "Pending Review" ?>
<option value='publish'><?php _e('Published') ?></option> <option value='publish'><?php _e('Published') ?></option>
<option value='future'><?php _e('Scheduled') ?></option> <option value='future'><?php _e('Scheduled') ?></option>
<?php endif; ?> <?php } ?>
<option value='pending'><?php _e('Pending Review') ?></option> <option value='pending'><?php _e('Pending Review') ?></option>
<option value='draft'><?php _e('Unpublished') ?></option> <option value='draft'><?php _e('Unpublished') ?></option>
</select> </select>
<?php if($type == 'page'): ?> </div>
<br /><label><input type="checkbox" name="page_private" value="private" <?php checked($post->post_status, 'private'); ?> /> <?php _e('Private') ?></label></p> </div>
<?php else: ?>
<?php if ( current_user_can( 'edit_others_posts' ) ) : ?> <?php if ( current_user_can( 'edit_others_posts' ) && ! $is_page ) { ?>
<br /><label><input type="checkbox" name="sticky" value="sticky" /> <?php _e('Sticky') ?></label></p> <div class="sticky quick-edit-div" <?php echo $style; ?> title="<?php _e('Sticky') ?>">
<?php endif; ?> <div class="title"><?php _e('Sticky'); ?></div>
<?php endif; ?> <div class="in">
</td> <label title="<?php _e('Sticky') ?>">
<?php <input type="checkbox" name="sticky" value="sticky" /> <?php _e('Stick this post to the front page') ?></label>
</div>
</div>
<?php }
break; break;
case 'control_view': ?> case 'control_view': ?>
<td><a href="<?php the_permalink(); ?>" rel="permalink" class="view"><?php _e('View'); ?></a></td> <div><a href="<?php the_permalink(); ?>" rel="permalink" class="view"><?php _e('View'); ?></a></div>
<?php <?php
break; break;
case 'control_edit': ?> case 'control_edit': ?>
<td><?php if ( current_user_can('edit_post',$post->ID) ) { echo "<a href='post.php?action=edit&amp;post=$id' class='edit'>" . __('Edit') . "</a>"; } ?></td> <div><?php if ( current_user_can('edit_post',$post->ID) ) { echo "<a href='post.php?action=edit&amp;post=$id' class='edit'>" . __('Edit') . "</a>"; } ?></div>
<?php <?php
break; break;
case 'control_delete': ?> case 'control_delete': ?>
<td><?php if ( current_user_can('delete_post',$post->ID) ) { echo "<a href='" . wp_nonce_url("post.php?action=delete&amp;post=$id", 'delete-post_' . $post->ID) . "' class='delete'>" . __('Delete') . "</a>"; } ?></td> <div><?php if ( current_user_can('delete_post',$post->ID) ) { echo "<a href='" . wp_nonce_url("post.php?action=delete&amp;post=$id", 'delete-post_' . $post->ID) . "' class='delete'>" . __('Delete') . "</a>"; } ?></div>
<?php <?php
break; break;
default: ?> default: ?>
<td><?php do_action('manage_posts_custom_column', $column_name, $post->ID); ?></td> <div><?php do_action('manage_posts_custom_column', $column_name, $post->ID); ?></div>
<?php <?php
break; break;
} }
} } ?>
echo '</tr>'; <div class="clear"></div>
<div class="quick-edit-save">
<a accesskey="c" href="#inline-edit" title="<?php _e('Cancel'); ?>" class="button-secondary cancel"><?php _e('Cancel'); ?></a>
<a accesskey="s" href="#inline-edit" title="<?php _e('Save'); ?>" class="button-secondary save"><?php _e('Save'); ?></a>
<?php wp_nonce_field( 'inlineeditnonce', '_inline_edit', false ) ?>
<input type="hidden" name="post_view" value="<?php echo $m; ?>" />
</div>
</td></tr>
<?php
} }
function inline_save_row( $data ) { function inline_save_row( $data ) {
@ -781,7 +810,7 @@ function inline_save_row( $data ) {
$data['content'] = $post['post_content']; $data['content'] = $post['post_content'];
// statuses // statuses
if ( 'page' == $data['post_type'] && 'private' == $data['page_private'] ) if ( 'private' == $data['keep_private'] )
$data['post_status'] = 'private'; $data['post_status'] = 'private';
if ( empty($data['comment_status']) ) if ( empty($data['comment_status']) )
$data['comment_status'] = 'closed'; $data['comment_status'] = 'closed';
@ -799,51 +828,44 @@ function inline_save_row( $data ) {
edit_post(); edit_post();
} }
// outputs XML of the post/page data ready for use in the inline editor // adds hidden fields with the data for use in the inline editor
// accepts array of post IDs function get_inline_data($post) {
function get_inline_data($posts) {
global $post;
header('Content-Type: text/xml; charset=' . get_option('blog_charset'), true); if ( ! current_user_can('edit_' . $post->post_type, $post->ID) )
echo "<?xml version='1.0' ?>\n"; return;
echo "<posts>\n";
foreach ($posts as $ID) { $title = apply_filters( 'the_title', $post->post_title );
$GLOBALS['post'] = get_post($ID); if ( empty($title) )
$GLOBALS['post_ID'] = $ID; $title = __('(no title)');
if ( ($post->post_type == 'post' && !current_user_can('edit_post', $ID)) || echo '
($post->post_type == 'page' && !current_user_can('edit_page', $ID)) || <div id="inline_' . $post->ID . '">
($post->post_type != 'post' && $post->post_type != 'page')) <input type="hidden" name="" class="post_title" value="' . $title . '" />
continue; <input type="hidden" name="" class="post_name" value="' . $post->post_name . '" />
<input type="hidden" name="" class="post_author" value="' . $post->post_author . '" />
<input type="hidden" name="" class="comment_status" value="' . $post->comment_status . '" />
<input type="hidden" name="" class="ping_status" value="' . $post->ping_status . '" />
<input type="hidden" name="" class="post_status" value="' . $post->post_status . '" />
<input type="hidden" name="" class="jj" value="' . mysql2date( 'd', $post->post_date ) . '" />
<input type="hidden" name="" class="mm" value="' . mysql2date( 'm', $post->post_date ) . '" />
<input type="hidden" name="" class="aa" value="' . mysql2date( 'Y', $post->post_date ) . '" />
<input type="hidden" name="" class="hh" value="' . mysql2date( 'H', $post->post_date ) . '" />
<input type="hidden" name="" class="mn" value="' . mysql2date( 'i', $post->post_date ) . '" />
<input type="hidden" name="" class="post_password" value="' . wp_specialchars($post->post_password, 1) . '" />';
echo " <post id='$ID'>\n"; if( $post->post_type == 'page' )
echo " <post_title>" . wp_specialchars($post->post_title, 1) . "</post_title>\n"; echo '
echo " <post_name>$post->post_name</post_name>\n"; <input type="hidden" name="" class="post_parent" value="' . $post->post_parent . '" />
echo " <post_author>$post->post_author</post_author>\n"; <input type="hidden" name="" class="page_template" value="' . wp_specialchars(get_post_meta( $post->ID, '_wp_page_template', true ), 1) . '" />
echo " <comment_status>$post->comment_status</comment_status>\n"; <input type="hidden" name="" class="menu_order" value="' . $post->menu_order . '" />';
echo " <ping_status>$post->ping_status</ping_status>\n";
echo " <post_status>$post->post_status</post_status>\n";
echo " <jj>" . mysql2date( 'd', $post->post_date ) . "</jj>\n";
echo " <mm>" . mysql2date( 'm', $post->post_date ) . "</mm>\n";
echo " <aa>" . mysql2date( 'Y', $post->post_date ) . "</aa>\n";
echo " <hh>" . mysql2date( 'H', $post->post_date ) . "</hh>\n";
echo " <mn>" . mysql2date( 'i', $post->post_date ) . "</mn>\n";
if( $post->post_type == 'post' ) {
echo ' <tags_input>' . wp_specialchars(get_tags_to_edit( $post->ID ), 1) . "</tags_input>\n";
echo ' <post_category>' . implode( ',', wp_get_post_categories( $post->ID ) ) . "</post_category>\n";
echo ' <sticky>' . (is_sticky($post->ID) ? 'sticky' : '') . "</sticky>\n";
}
if( $post->post_type == 'page' ) {
echo " <post_parent>$post->post_parent</post_parent>\n";
echo ' <page_template>' . wp_specialchars(get_post_meta( $post->ID, '_wp_page_template', true ), 1) . "</page_template>\n";
echo " <post_password>" . wp_specialchars($post->post_password, 1) . "</post_password>\n";
echo " <menu_order>$post->menu_order</menu_order>\n";
}
echo " </post>\n";
}
echo '</posts>'; if( $post->post_type == 'post' )
echo '
<input type="hidden" name="" class="tags_input" value="' . wp_specialchars( str_replace( ',', ', ', get_tags_to_edit($post->ID) ), 1) . '" />
<input type="hidden" name="" class="post_category" value="' . implode( ',', wp_get_post_categories( $post->ID ) ) . '" />
<input type="hidden" name="" class="sticky" value="' . (is_sticky($post->ID) ? 'sticky' : '') . '" />';
echo '</div>';
} }
function post_rows( $posts = array() ) { function post_rows( $posts = array() ) {
@ -874,13 +896,13 @@ function post_rows( $posts = array() ) {
function _post_row($a_post, $pending_comments, $mode) { function _post_row($a_post, $pending_comments, $mode) {
global $post; global $post;
static $class; static $rowclass;
$global_post = $post; $global_post = $post;
$post = $a_post; $post = $a_post;
setup_postdata($post); setup_postdata($post);
$class = 'alternate' == $class ? '' : 'alternate'; $rowclass = 'alternate' == $rowclass ? '' : 'alternate';
global $current_user; global $current_user;
$post_owner = ( $current_user->ID == $post->post_author ? 'self' : 'other' ); $post_owner = ( $current_user->ID == $post->post_author ? 'self' : 'other' );
$edit_link = get_edit_post_link( $post->ID ); $edit_link = get_edit_post_link( $post->ID );
@ -888,7 +910,7 @@ function _post_row($a_post, $pending_comments, $mode) {
if ( empty($title) ) if ( empty($title) )
$title = __('(no title)'); $title = __('(no title)');
?> ?>
<tr id='post-<?php echo $post->ID; ?>' class='<?php echo trim( $class . ' author-' . $post_owner . ' status-' . $post->post_status ); ?>' valign="top"> <tr id='post-<?php echo $post->ID; ?>' class='<?php echo trim( $rowclass . ' author-' . $post_owner . ' status-' . $post->post_status ); ?> iedit' valign="top">
<?php <?php
$posts_columns = wp_manage_posts_columns(); $posts_columns = wp_manage_posts_columns();
$hidden = (array) get_user_option( 'manage-post-columns-hidden' ); $hidden = (array) get_user_option( 'manage-post-columns-hidden' );
@ -934,11 +956,13 @@ function _post_row($a_post, $pending_comments, $mode) {
} }
} }
if ( 'excerpt' == $mode ) { ?> echo '<td ' . $attributes . '>';
<td <?php echo $attributes ?>><?php echo apply_filters('post_date_column_time', $t_time, $post, $column_name, $mode) ?></td> if ( 'excerpt' == $mode )
<?php } else { ?> echo apply_filters('post_date_column_time', $t_time, $post, $column_name, $mode);
<td <?php echo $attributes ?>><abbr title="<?php echo $t_time ?>"><?php echo apply_filters('post_date_column_time', $h_time, $post, $column_name, $mode) ?></abbr></td> else
<?php } echo '<abbr title="' . $t_time . '">' . apply_filters('post_date_column_time', $h_time, $post, $column_name, $mode) . '</abbr>';
echo '</td>';
break; break;
case 'title': case 'title':
@ -966,6 +990,8 @@ function _post_row($a_post, $pending_comments, $mode) {
( $i == $action_count ) ? $sep = '' : $sep = ' | '; ( $i == $action_count ) ? $sep = '' : $sep = ' | ';
echo "<span class='$action'>$link$sep</span>"; echo "<span class='$action'>$link$sep</span>";
} }
get_inline_data($post);
?> ?>
</td> </td>
<?php <?php
@ -1088,7 +1114,7 @@ function _post_row($a_post, $pending_comments, $mode) {
*/ */
function display_page_row( $page, $level = 0 ) { function display_page_row( $page, $level = 0 ) {
global $post; global $post;
static $class; static $rowclass;
$post = $page; $post = $page;
setup_postdata($page); setup_postdata($page);
@ -1096,16 +1122,14 @@ function display_page_row( $page, $level = 0 ) {
$page->post_title = wp_specialchars( $page->post_title ); $page->post_title = wp_specialchars( $page->post_title );
$pad = str_repeat( '&#8212; ', $level ); $pad = str_repeat( '&#8212; ', $level );
$id = (int) $page->ID; $id = (int) $page->ID;
$class = ('alternate' == $class ) ? '' : 'alternate'; $rowclass = 'alternate' == $rowclass ? '' : 'alternate';
$posts_columns = wp_manage_pages_columns(); $posts_columns = wp_manage_pages_columns();
$hidden = (array) get_user_option( 'manage-page-columns-hidden' ); $hidden = (array) get_user_option( 'manage-page-columns-hidden' );
$title = get_the_title(); $title = get_the_title();
if ( empty($title) ) if ( empty($title) )
$title = __('(no title)'); $title = __('(no title)');
?> ?>
<tr id='page-<?php echo $id; ?>' class='<?php echo $class; ?>'> <tr id="page-<?php echo $id; ?>" class="<?php echo $rowclass; ?> iedit">
<?php <?php
foreach ($posts_columns as $column_name=>$column_display_name) { foreach ($posts_columns as $column_name=>$column_display_name) {
@ -1175,9 +1199,9 @@ foreach ($posts_columns as $column_name=>$column_display_name) {
( $i == $action_count ) ? $sep = '' : $sep = ' | '; ( $i == $action_count ) ? $sep = '' : $sep = ' | ';
echo "<span class='$action'>$link$sep</span>"; echo "<span class='$action'>$link$sep</span>";
} }
?>
</td> get_inline_data($post);
<?php echo '</td>';
break; break;
case 'comments': case 'comments':

View File

@ -1,130 +1,97 @@
var postType = null;
var postView = null;
var postsXml = null;
var inlineRows = null;
jQuery(document).ready(function() { (function($) {
postType = window.location.href.indexOf('edit.php') == -1 ? 'page' : 'post'; inlineEdit = {
postView = window.location.href.indexOf('mode=excerpt') == -1 ? 'list' : 'excerpt'; type : '',
rows : '',
// get IDs of all editable rows init : function() {
inlineRows = jQuery('table.widefat .check-column :checkbox[name="post[]"]').parents('tr'); var t = this, blankRow = $('#inline-edit');
t.type = $('table.widefat').hasClass('page') ? 'page' : 'post';
// get all editable rows
t.rows = $('tr.iedit');
// prepare the edit row // prepare the edit row
var blankRow = jQuery('#inline-edit'); blankRow.dblclick(function() { inlineEdit.toggle(this); })
jQuery('ul.categories *', blankRow).removeAttr('id'); .keyup(function(e) { if(e.which == 27) return inlineEdit.revert(this); });
jQuery('ul.categories label', blankRow).removeAttr('for');
blankRow.attr('title', 'Double-click to cancel')
.dblclick(function() { toggleRow(this); })
.keypress(function(event) { if(event.which == 13) return saveRow(this); });
jQuery('span.cancel a', blankRow).click(function() { return revertRow(this); });
jQuery('span.save a', blankRow).click(function() { return saveRow(this); });
// add events and get data $('a.cancel', blankRow).click(function() { return inlineEdit.revert(this); });
inlineRows.dblclick(function() { toggleRow(this); }); $('a.save', blankRow).click(function() { return inlineEdit.save(this); });
addEvents(inlineRows);
// get data // add events
getInlineData('all'); t.rows.dblclick(function() { inlineEdit.toggle(this); });
}); t.addEvents(t.rows);
function toggleRow(el) {
jQuery('#'+postType+'-'+getRowId(el)).css('display') == 'none' ? revertRow(el) : editRow(el);
}
// add events to links and make rows double-clickable
function addEvents(rows) {
rows.each(function() {
var row = jQuery(this);
jQuery('a.editinline', row).click(function() { editRow(this); return false; });
row.attr('title', 'Double-click to edit');
});
}
function getInlineData(id) {
if(id == 'all') {
var editable = [];
inlineRows.each(function(i) { editable[i] = getRowId(this); });
id = editable.join(',');
}
if(id == '')
return false;
jQuery.post('admin-ajax.php', {
'inline_edit_nonce': jQuery('#inline_edit_nonce').val(),
action: 'inline-data',
posts: id
}, },
function(xml) {
if(id.indexOf(',') == -1) {
var newData = jQuery(xml).find('post[id="'+id+'"]');
jQuery(postsXml).find('post[id="'+id+'"]').replaceWith(newData);
} else {
postsXml = xml;
}
}, 'xml'
);
}
function editRow(id) { toggle : function(el) {
var t = this;
$('#'+t.type+'-'+t.getId(el)).css('display') == 'none' ? t.revert(el) : t.edit(el);
},
addEvents : function(r) {
r.each(function() {
var row = $(this);
$('a.editinline', row).click(function() { inlineEdit.edit(this); return false; });
row.attr('title', inlineEditL10n.edit);
});
},
edit : function(id) {
var t = this, type = t.type, old = $('tr.inline-editor').attr('id');
if( typeof(id) == 'object' ) if( typeof(id) == 'object' )
id = getRowId(id); id = t.getId(id);
var blankRow = jQuery('#inline-edit'); if ( old ) {
old = old.split('-')[1];
t.revert(old);
}
var fields = ['post_title', 'post_name', 'post_author', 'post_status', 'jj', 'mm', 'aa', 'hh', 'mn']; var fields = ['post_title', 'post_name', 'post_author', 'post_status', 'jj', 'mm', 'aa', 'hh', 'mn', 'post_password'];
if(postType == 'page') fields.push('post_parent', 'menu_order', 'page_template', 'post_password'); if ( type == 'page' ) fields.push('post_parent', 'menu_order', 'page_template');
if(postType == 'post') fields.push('tags_input'); if ( type == 'post' ) fields.push('tags_input');
// add the new blank row // add the new blank row
var editRow = blankRow.clone(true); var editRow = $('#inline-edit').clone(true);
jQuery(editRow).attr('id', 'edit-'+id).addClass('inline-editor').show();
if(jQuery('#'+postType+'-'+id).hasClass('alternate')) if ( $('#'+type+'-'+id).hasClass('alternate') )
jQuery(editRow).addClass('alternate'); $(editRow).addClass('alternate');
jQuery('#'+postType+'-'+id).hide().after(editRow); $('#'+type+'-'+id).hide().after(editRow);
// populate the data // populate the data
var rowData = jQuery(postsXml).find('post[id="'+id+'"]'); var rowData = $('#inline_'+id);
for ( var f = 0; f < fields.length; f++ ) { for ( var f = 0; f < fields.length; f++ ) {
jQuery(':input[name="'+fields[f]+'"]', editRow).val(jQuery(fields[f], rowData).text()); $(':input[name="'+fields[f]+'"]', editRow).val( $('.'+fields[f], rowData).val() );
} }
// ping, comments, and privacy if ( $('.comment_status', rowData).val() == 'open' )
if(jQuery('comment_status', rowData).text() == 'open') $('input[name="comment_status"]', editRow).attr("checked", "checked");
jQuery('input[name="comment_status"]', editRow).select(); if ( $('.ping_status', rowData).val() == 'open' )
if(jQuery('ping_status', rowData).text() == 'open') $('input[name="ping_status"]', editRow).attr("checked", "checked");
jQuery('input[name="ping_status"]', editRow).select(); if ( $('.sticky', rowData).val() == 'sticky' )
if(jQuery('sticky', rowData).text() == 'sticky') $('input[name="sticky"]', editRow).attr("checked", "checked");
jQuery('input[name="sticky"]', editRow).select();
// categories // categories
var categories = jQuery('post_category', rowData).text().split(','); var cats;
jQuery(categories).each(function() { if ( cats = $('.post_category', rowData).val() )
jQuery('ul.categories :checkbox[value="'+this+'"]', editRow).select(); $('ul.cat-checklist :checkbox').val(cats.split(','));
});
// handle the post status // handle the post status
var status = jQuery('post_status', rowData).text(); var status = $('.post_status', rowData).val();
if(status != 'future') jQuery('select[name="post_status"] option[value="future"]', editRow).remove(); if ( status != 'future' ) $('select[name="post_status"] option[value="future"]', editRow).remove();
if(status == 'private') jQuery('input[name="page_private"]', editRow).select(); if ( status == 'private' ) $('input[name="keep_private"]', editRow).attr("checked", "checked");
// enable autocomplete for tags
if(postType == 'post') {
jQuery('tr.inline textarea[name="tags_input"]').suggest( 'admin-ajax.php?action=ajax-tag-search', { delay: 500, minchars: 2, multiple: true, multipleSep: ", " } );
}
// remove the current page and children from the parent dropdown // remove the current page and children from the parent dropdown
var pageOpt = jQuery('select[name="post_parent"] option[value="'+id+'"]', editRow); var pageOpt = $('select[name="post_parent"] option[value="'+id+'"]', editRow);
if ( pageOpt.length > 0 ) { if ( pageOpt.length > 0 ) {
var pageLevel = pageOpt[0].className.split('-')[1]; var pageLevel = pageOpt[0].className.split('-')[1], nextPage = pageOpt, pageLoop = true;
var nextPage = pageOpt; var pageLoop = true;
while ( pageLoop ) { while ( pageLoop ) {
var nextPage = nextPage.next('option'); var nextPage = nextPage.next('option'), nextLevel = nextPage[0].className.split('-')[1];
var nextLevel = nextPage[0].className.split('-')[1]; if ( nextLevel <= pageLevel ) {
if(nextLevel <= pageLevel)
pageLoop = false; pageLoop = false;
else { } else {
nextPage.remove(); nextPage.remove();
nextPage = pageOpt; nextPage = pageOpt;
} }
@ -132,56 +99,76 @@ function editRow(id) {
pageOpt.remove(); pageOpt.remove();
} }
// categories expandable?
$('span.catshow', editRow).click(function() {
$('ul.cat-checklist', editRow).addClass("cat-hover");
$('span.cathide', editRow).show();
$(this).hide();
});
$('span.cathide', editRow).click(function() {
$('ul.cat-checklist', editRow).removeClass("cat-hover");
$('span.catshow', editRow).show();
$(this).hide();
});
$(editRow).attr('id', 'edit-'+id).addClass('inline-editor').show();
$('.ptitle', editRow).focus();
// enable autocomplete for tags
if ( type == 'post' )
$('tr.inline-editor textarea[name="tags_input"]').suggest( 'admin-ajax.php?action=ajax-tag-search', { delay: 500, minchars: 2, multiple: true, multipleSep: ", " } );
return false; return false;
} },
function saveRow(id) { save : function(id) {
if( typeof(id) == 'object' ) if( typeof(id) == 'object' )
id = getRowId(id); id = this.getId(id);
jQuery('#edit-'+id+' .check-column').html('<img src="images/loading.gif" alt="" />'); $('#edit-'+id+' .check-column').html('<img src="images/loading.gif" alt="" />');
var params = { var params = {
'inline_edit_nonce': jQuery('#inline_edit_nonce').val(),
action: 'inline-save', action: 'inline-save',
post_type: postType, post_type: this.type,
post_ID: id, post_ID: id,
edit_date: 'true', edit_date: 'true'
post_view: postView
}; };
var fields = jQuery('#edit-'+id+' :input').fieldSerialize(); var fields = $('#edit-'+id+' :input').fieldSerialize();
params = fields + '&' + jQuery.param(params); params = fields + '&' + $.param(params);
// make ajax request // make ajax request
jQuery.post('admin-ajax.php', params, $.post('admin-ajax.php', params,
function(html) { function(html) {
var row = jQuery('#'+postType+'-'+id); var row = $('#'+inlineEdit.type+'-'+id);
jQuery('#edit-'+id).hide(); $('#edit-'+id).hide();
html = jQuery(html).html(); html = $(html).html();
row.html(html).show(); row.html(html).show();
row.animate( { backgroundColor: '#FFFBCC' }, 200) row.animate( { backgroundColor: '#FFFBCC' }, 200)
.animate( { backgroundColor: row.css('background-color') }, 500); .animate( { backgroundColor: row.css('background-color') }, 500);
getInlineData(id); inlineEdit.addEvents(row);
addEvents(row);
} }
); );
return false; return false;
} },
function revertRow(id) { revert : function(id) {
if ( typeof(id) == 'object' ) if ( typeof(id) == 'object' )
id = getRowId(id); id = this.getId(id);
jQuery('#edit-'+id).remove(); $('#edit-'+id).remove();
jQuery('#'+postType+'-'+id).show(); $('#'+this.type+'-'+id).show();
return false; return false;
} },
function getRowId(obj) { getId : function(o) {
var id = obj.tagName == 'TR' ? obj.id : jQuery(obj).parents('tr').attr('id'); var id = o.tagName == 'TR' ? o.id : $(o).parents('tr').attr('id');
var parts = id.split('-'); var parts = id.split('-');
return parts[parts.length - 1]; return parts[parts.length - 1];
} }
};
$(document).ready(function(){inlineEdit.init();});
})(jQuery);

View File

@ -2159,120 +2159,162 @@ a.togbox {
font-size: 11px; font-size: 11px;
} }
.inline-editor .save {
padding-top: 5px;
}
.inline-editor td { .inline-editor td {
padding-right: 4px; padding: 3px;
padding-left: 7px;
} }
.inline-editor input, .inline-editor select, .inline-editor textarea { .inline-editor .save,
font-size: 10px !important; .inline-editor .cancel {
margin-right: 5px;
}
.inline-editor .quick-edit-div {
float: left;
height: 85px;
margin: 0 5px 3px 0;
width: 130px;
border-style: solid;
border-width: 1px;
padding: 2px; padding: 2px;
border: 1px solid #ddd;
} }
.inline-editor td.date { .inline-editor .in {
width: 87px; padding: 4px;
margin: 2px 0 0;
line-height: 15px;
} }
.inline-editor td.page-title { .inline-editor input {
width: 495px; font-size: 11px !important;
padding: 2px;
border-width: 1px;
border-style: solid;
} }
.inline-editor td.post-title input.title { #wpbody-content .inline-editor select {
width: 250px; padding: 0;
} height: auto;
width: 120px;
.inline-editor td.post-title input.slug { font-size: 11px !important;
width: 222px;
float: right;
} }
.inline-editor div.title { .inline-editor div.title {
float: left; padding: 2px 5px;
cursor: default;
} }
.inline-editor div.title input.title { .inline-editor .post-title,
.inline-editor .page-title {
width: 260px;
}
.inline-editor .post-title .ptitle,
.inline-editor .page-title .ptitle {
width: 245px;
margin-bottom: 5px;
font-size: 12px !important; font-size: 12px !important;
} }
.inline-editor div.title label { .inline-editor .post-title .slug,
float: left; .inline-editor .page-title .slug {
margin-top: 4px; text-align: right;
} }
.inline-editor td.page-title input.slug { .inline-editor .slug input {
width: 123px; width: 170px;
float: right; margin: 0 2px 0 4px;
} }
.inline-editor div.other, .inline-editor div.more { .inline-editor .password input,
width: 190px; .inline-editor .order input {
float: left; width: 112px;
padding-left: 5px;
} }
.inline-editor div.other label, .inline-editor div.more label { .inline-editor .password label input {
display: block; float: left; width: auto;
width: 54px; margin: 3px 0 0;
margin-top: 4px;
} }
.inline-editor div.other select { .inline-editor .date {
width: 133px; width: 160px;
} }
.inline-editor div.more { .inline-editor .date input {
width: 125px; padding: 2px 1px;
margin: 1px;
width: 18px;
} }
.inline-editor div.more input { .inline-editor .date input[name="aa"] {
width: 60px; width: 30px;
} }
.inline-editor td.author select { #wpbody-content .inline-editor .date select {
width: 110px; width: 80px;
} }
.inline-editor ul.categories { .inline-editor .categories {
width: 180px;
}
.inline-editor .categories ul.cat-checklist {
list-style: none; list-style: none;
padding: 0; margin: 0; padding: 0 0 0 4px;
margin: 0;
height: 65px; height: 65px;
overflow: auto; overflow: auto;
font-size: 10px; font-size: 11px;
z-index: 5;
position: relative;
overflow-x: hidden;
} }
.inline-editor ul.categories ul.children { .inline-editor .categories ul.cat-hover {
height: 200px;
overflow: auto;
}
.inline-editor .categories ul.children {
list-style: none; list-style: none;
padding-left: 15px; padding-left: 15px;
} }
.inline-editor ul.categories li { .inline-editor .categories li {
margin-bottom: 2px; margin-bottom: 3px;
line-height: auto;
} }
.inline-editor ul.categories input { .inline-editor .categories input {
vertical-align: middle; vertical-align: middle;
padding: 0; border: 0; padding: 0;
border: 0;
} }
.inline-editor td.tags textarea { .inline-editor .categories .catshow,
height: 58px; width: 100%; .inline-editor .categories .cathide {
font-size: 9px;
cursor: pointer;
} }
.inline-editor td.comments { .inline-editor .tags {
padding-left: 0; width: 220px;
} }
.inline-editor td.status select { .inline-editor textarea {
width: 98px; border-width: 1px;
border-style: solid;
height: 45px;
width: 200px;
font-size: 11px;
} }
.inline-editor td.status input { .inline-editor .comments {
vertical-align: middle; text-align: left;
width: 160px;
}
.inline-editor .quick-edit-save {
padding: 8px 10px;
} }
/* Media library */ /* Media library */

View File

@ -244,7 +244,10 @@ function wp_default_scripts( &$scripts ) {
$scripts->add( 'theme-preview', '/wp-admin/js/theme-preview.js', array( 'thickbox', 'jquery' ), '20080625' ); $scripts->add( 'theme-preview', '/wp-admin/js/theme-preview.js', array( 'thickbox', 'jquery' ), '20080625' );
$scripts->add( 'inline-edit', '/wp-admin/js/inline-edit.js', array( 'jquery', 'jquery-form', 'suggest' ), '20080812' ); $scripts->add( 'inline-edit', '/wp-admin/js/inline-edit.js', array( 'jquery', 'jquery-form', 'suggest' ), '20080920' );
$scripts->localize( 'inline-edit', 'inlineEditL10n', array(
'edit' => __('Double-click to edit')
) );
$scripts->add( 'plugin-install', '/wp-admin/js/plugin-install.js', array( 'thickbox', 'jquery' ), '20080803' ); $scripts->add( 'plugin-install', '/wp-admin/js/plugin-install.js', array( 'thickbox', 'jquery' ), '20080803' );
$scripts->localize( 'plugin-install', 'plugininstallL10n', array( $scripts->localize( 'plugin-install', 'plugininstallL10n', array(