From 7740e89de3e1bc0cc636120e3ca8ab9e97e4d3cc Mon Sep 17 00:00:00 2001
From: donncha comment_author_email) { ?>| comment_author_url && 'http://' != $comment->comment_author_url) { ?> | | — [
-comment_post_ID) ) {
- echo " " . __('Edit') . '';
- echo ' | comment_author)) . "', theCommentList );\">" . __('Delete') . ' ';
- if ( ('none' != $comment_status) && ( current_user_can('moderate_comments') ) ) {
- echo ' | ' . __('Unapprove') . ' ';
- echo ' | ' . __('Approve') . ' ';
+ $post_link .= get_the_title($comment->comment_post_ID) . 'term_id ) . "' onclick=\"return deleteSomething( 'cat', $category->term_id, '" . js_escape(sprintf( __("You are about to delete the category '%s'.\nAll posts that were only assigned to this category will be assigned to the '%s' category.\nAll links that were only assigned to this category will be assigned to the '%s' category.\n'OK' to delete, 'Cancel' to stop." ), $category->name, get_catname( $default_cat_id ), get_catname( $default_link_cat_id ) )) . "' );\" class='delete'>".__( 'Delete' )."";
- else
- $edit .= " ".__( "Default" );
- } else
- $edit = '';
+ $edit = "name)) . "'>$name";
+ } else {
+ $edit = $name;
+ }
- $class = ( ( defined( 'DOING_AJAX' ) && DOING_AJAX ) || " class='alternate'" == $class ) ? '' : " class='alternate'";
+ $class = " class='alternate'" == $class ? '' : " class='alternate'";
$category->count = number_format_i18n( $category->count );
$posts_count = ( $category->count > 0 ) ? "$category->count" : $category->count;
$output = "
- \n";
+ $category->term_id
- " . ( $name_override ? $name_override : $pad . ' ' . $category->name ) . "
- $category->description
- $posts_count
- $edit \n\t";
+ if ( absint(get_option( 'default_category' ) ) != $category->term_id ) {
+ $output .= " ";
+ } else {
+ $output .= " ";
+ }
+ $output .= "$edit
+ $category->description
+ $posts_count \n\t\n";
return apply_filters('cat_row', $output);
}
+function link_cat_row( $category ) {
+ global $class;
+
+ if ( !$category = get_term( $category, 'link_category' ) )
+ return false;
+ if ( is_wp_error( $category ) )
+ return $category;
+
+ $name = ( $name_override ? $name_override : $category->name );
+ if ( current_user_can( 'manage_categories' ) ) {
+ $edit = "name)) . "' class='edit'>$name";
+ $default_cat_id = (int) get_option( 'default_link_category' );
+ } else {
+ $edit = $name;
+ }
+
+ $class = " class='alternate'" == $class ? '' : " class='alternate'";
+
+ $category->count = number_format_i18n( $category->count );
+ $count = ( $category->count > 0 ) ? "$category->count" : $category->count;
+ $output = "" .
+ ' ";
+
+ return apply_filters( 'link_cat_row', $output );
+}
+
function checked( $checked, $current) {
if ( $checked == $current)
echo ' checked="checked"';
}
-// TODO: Remove?
-function documentation_link( $for ) {
- return;
-}
-
function selected( $selected, $current) {
if ( $selected == $current)
echo ' selected="selected"';
@@ -87,8 +116,8 @@ function sort_cats( $cat1, $cat2 ) {
return strcasecmp( $cat1['cat_name'], $cat2['cat_name'] );
}
-function get_nested_categories( $default = 0, $parent = 0 ) {
- global $post_ID, $mode, $wpdb, $checked_categories;
+function wp_set_checked_post_categories( $default = 0 ) {
+ global $post_ID, $checked_categories;
if ( empty($checked_categories) ) {
if ( $post_ID ) {
@@ -103,15 +132,33 @@ function get_nested_categories( $default = 0, $parent = 0 ) {
}
}
- $cats = get_categories("parent=$parent&hide_empty=0&fields=ids");
+}
+function get_nested_categories( $default = 0, $parent = 0 ) {
+ global $checked_categories;
+
+ wp_set_checked_post_categories( $default = 0 );
+
+ if ( is_object($parent) ) { // Hack: if passed a category object, will return nested cats with parent as root
+ $root = array(
+ 'children' => get_nested_categories( $default, $parent->term_id ),
+ 'cat_ID' => $parent->term_id,
+ 'checked' => in_array( $parent->term_id, $checked_categories ),
+ 'cat_name' => get_the_category_by_ID( $parent->term_id )
+ );
+ $result = array( $parent->term_id => $root );
+ } else {
+ $parent = (int) $parent;
+
+ $cats = get_categories("parent=$parent&hide_empty=0&fields=ids");
- $result = array ();
- if ( is_array( $cats ) ) {
- foreach ( $cats as $cat) {
- $result[$cat]['children'] = get_nested_categories( $default, $cat);
- $result[$cat]['cat_ID'] = $cat;
- $result[$cat]['checked'] = in_array( $cat, $checked_categories );
- $result[$cat]['cat_name'] = get_the_category_by_ID( $cat);
+ $result = array();
+ if ( is_array( $cats ) ) {
+ foreach ( $cats as $cat ) {
+ $result[$cat]['children'] = get_nested_categories( $default, $cat );
+ $result[$cat]['cat_ID'] = $cat;
+ $result[$cat]['checked'] = in_array( $cat, $checked_categories );
+ $result[$cat]['cat_name'] = get_the_category_by_ID( $cat );
+ }
}
}
@@ -123,18 +170,37 @@ function get_nested_categories( $default = 0, $parent = 0 ) {
function write_nested_categories( $categories ) {
foreach ( $categories as $category ) {
- echo '";
+ echo "\n", ' ' .
+ "$edit
+ $category->description
+ $count \n";
+ echo "\n
";
}
+ echo '";
write_nested_categories( $category['children'] );
- echo "
\n";
+ echo "\n';
+ $out .= ' ';
+
+ return $out;
+}
- foreach ( $pages as $post) {
- setup_postdata( $post);
- if ( $hierarchy && ($post->post_parent != $parent) )
- continue;
+// Outputs appropriate rows for the Nth page of the Tag Management screen,
+// assuming M tags displayed at a time on the page
+// Returns the number of tags displayed
+function tag_rows( $page = 1, $pagesize = 20, $searchterms = '' ) {
- $post->post_title = wp_specialchars( $post->post_title );
- $pad = str_repeat( '— ', $level );
- $id = (int) $post->ID;
- $class = ('alternate' == $class ) ? '' : 'alternate';
+ // Get a page worth of tags
+ $start = ($page - 1) * $pagesize;
+
+ $args = array('offset' => $start, 'number' => $pagesize, 'hide_empty' => 0);
+
+ if ( !empty( $searchterms ) ) {
+ $args['search'] = $searchterms;
+ }
+
+ $tags = get_terms( 'post_tag', $args );
+
+ // convert it to table rows
+ $out = '';
+ $class = '';
+ $count = 0;
+ foreach( $tags as $tag )
+ $out .= _tag_row( $tag, ++$count % 2 ? ' class="alternate"' : '' );
+
+ // filter and send to screen
+ $out = apply_filters('tag_rows', $out);
+ echo $out;
+ return $count;
+}
+
+// define the columns to display, the syntax is 'internal name' => 'display name'
+function wp_manage_posts_columns() {
+ $posts_columns = array();
+ $posts_columns['cb'] = '';
+ if ( 'draft' === $_GET['post_status'] )
+ $posts_columns['modified'] = __('Modified');
+ elseif ( 'pending' === $_GET['post_status'] )
+ $posts_columns['modified'] = __('Submitted');
+ else
+ $posts_columns['date'] = __('Date');
+ $posts_columns['title'] = __('Title');
+ $posts_columns['author'] = __('Author');
+ $posts_columns['categories'] = __('Categories');
+ $posts_columns['tags'] = __('Tags');
+ if ( !in_array($_GET['post_status'], array('pending', 'draft', 'future')) )
+ $posts_columns['comments'] = ' ';
+ $out .= '' .
+ $name . ' ';
+
+ $out .= "$count ";
+ $out .= '


-
+
+
+ $column_display_name) {
+
+ switch ($column_name) {
+
+ case 'cb':
+ ?>
+ ID; ?>
-
-
-
-
- post_modified ) _e('Unpublished'); else echo mysql2date( __('Y-m-d g:i a'), $post->post_modified ); ?>
-
- " . __( 'Edit' ) . ""; } ?>
- " . __( 'Delete' ) . ""; } ?>
-
+ post_date && 'date' == $column_name ) {
+ $t_time = $h_time = __('Unpublished');
+ } else {
+ if ( 'modified' == $column_name ) {
+ $t_time = get_the_modified_time(__('Y/m/d g:i:s A'));
+ $m_time = $page->post_modified;
+ $time = get_post_modified_time('G', true);
+ } else {
+ $t_time = get_the_time(__('Y/m/d g:i:s A'));
+ $m_time = $page->post_date;
+ $time = get_post_time('G', true);
+ }
+ if ( ( abs(time() - $time) ) < 86400 ) {
+ if ( ( 'future' == $page->post_status) )
+ $h_time = sprintf( __('%s from now'), human_time_diff( $time ) );
+ else
+ $h_time = sprintf( __('%s ago'), human_time_diff( $time ) );
+ } else {
+ $h_time = mysql2date(__('Y/m/d'), $m_time);
+ }
+ }
+ ?>
+
+
+ ">
+ post_status) _e(' — Private'); ?>
+
+
+
+
+
+
+ " rel="permalink">
+ post_status ) {
+ case 'publish' :
+ case 'private' :
+ _e('Published');
+ break;
+ case 'future' :
+ _e('Scheduled');
+ break;
+ case 'pending' :
+ _e('Pending Review');
+ break;
+ case 'draft' :
+ _e('Unpublished');
+ break;
+ }
+ ?>
+
+
+
+
+
+
+
post_parent == $id ) {
+ array_splice($children_pages, $i, 1);
+ display_page_row($child, $children_pages, $level+1);
+ $i = -1; //as numeric keys in $children_pages are not preserved after splice
+ }
+ }
+}
+
+/*
+ * displays pages in hierarchical order
+ */
+function page_rows( $pages ) {
+ if ( ! $pages )
+ $pages = get_pages( 'sort_column=menu_order' );
+
+ if ( ! $pages )
+ return false;
+
+ // splice pages into two parts: those without parent and those with parent
+
+ $top_level_pages = array();
+ $children_pages = array();
+
+ foreach ( $pages as $page ) {
+
+ // catch and repair bad pages
+ if ( $page->post_parent == $page->ID ) {
+ $page->post_parent = 0;
+ $wpdb->query( $wpdb->prepare("UPDATE $wpdb->posts SET post_parent = '0' WHERE ID = %d", $page->ID) );
+ clean_page_cache( $page->ID );
+ }
+
+ if ( 0 == $page->post_parent )
+ $top_level_pages[] = $page;
+ else
+ $children_pages[] = $page;
}
+
+ foreach ( $top_level_pages as $page )
+ display_page_row($page, $children_pages, 0);
+
+ /*
+ * display the remaining children_pages which are orphans
+ * having orphan requires parental attention
+ */
+ if ( count($children_pages) > 0 ) {
+ $empty_array = array();
+ foreach ( $children_pages as $orphan_page ) {
+ clean_page_cache( $orphan_page->ID);
+ display_page_row( $orphan_page, $empty_array, 0 );
+ }
+ }
}
-function user_row( $user_object, $style = '' ) {
- global $current_user;
+function user_row( $user_object, $style = '', $role = '' ) {
+ global $wp_roles;
- if ( !(is_object( $user_object) && is_a( $user_object, 'WP_User' ) ) )
+ $current_user = wp_get_current_user();
+
+ if ( !( is_object( $user_object) && is_a( $user_object, 'WP_User' ) ) )
$user_object = new WP_User( (int) $user_object );
$email = $user_object->user_email;
$url = $user_object->user_url;
@@ -214,33 +543,50 @@ function user_row( $user_object, $style = '' ) {
if ( strlen( $short_url ) > 35 )
$short_url = substr( $short_url, 0, 32 ).'...';
$numposts = get_usernumposts( $user_object->ID );
+ if ( current_user_can( 'edit_user', $user_object->ID ) ) {
+ if ($current_user->ID == $user_object->ID) {
+ $edit = 'profile.php';
+ } else {
+ $edit = clean_url( add_query_arg( 'wp_http_referer', urlencode( clean_url( stripslashes( $_SERVER['REQUEST_URI'] ) ) ), "user-edit.php?user_id=$user_object->ID" ) );
+ }
+ $edit = "$user_object->user_login";
+ } else {
+ $edit = $user_object->user_login;
+ }
+ $role_name = translate_with_context($wp_roles->role_names[$role]);
$r = "
- ";
return $r;
}
-function _wp_get_comment_list( $s = false, $start, $num ) {
+function _wp_get_comment_list( $status = '', $s = false, $start, $num ) {
global $wpdb;
$start = abs( (int) $start );
$num = (int) $num;
+ if ( 'moderated' == $status )
+ $approved = "comment_approved = '0'";
+ elseif ( 'approved' == $status )
+ $approved = "comment_approved = '1'";
+ elseif ( 'spam' == $status )
+ $approved = "comment_approved = 'spam'";
+ else
+ $approved = "comment_approved != 'spam'";
+
if ( $s ) {
$s = $wpdb->escape($s);
$comments = $wpdb->get_results("SELECT SQL_CALC_FOUND_ROWS * FROM $wpdb->comments WHERE
@@ -249,10 +595,10 @@ function _wp_get_comment_list( $s = false, $start, $num ) {
comment_author_url LIKE ('%$s%') OR
comment_author_IP LIKE ('%$s%') OR
comment_content LIKE ('%$s%') ) AND
- comment_approved != 'spam'
- ORDER BY comment_date DESC LIMIT $start, $num");
+ $approved
+ ORDER BY comment_date_gmt DESC LIMIT $start, $num");
} else {
- $comments = $wpdb->get_results( "SELECT SQL_CALC_FOUND_ROWS * FROM $wpdb->comments WHERE comment_approved = '0' OR comment_approved = '1' ORDER BY comment_date DESC LIMIT $start, $num" );
+ $comments = $wpdb->get_results( "SELECT SQL_CALC_FOUND_ROWS * FROM $wpdb->comments USE INDEX (comment_date_gmt) WHERE $approved ORDER BY comment_date_gmt DESC LIMIT $start, $num" );
}
update_comment_cache($comments);
@@ -262,46 +608,95 @@ function _wp_get_comment_list( $s = false, $start, $num ) {
return array($comments, $total);
}
-function _wp_comment_list_item( $id, $alt = 0 ) {
- global $authordata, $comment, $wpdb;
- $id = (int) $id;
- $comment =& get_comment( $id );
- $class = '';
+function _wp_comment_row( $comment_id, $mode, $comment_status, $checkbox = true ) {
+ global $comment, $post;
+ $comment = get_comment( $comment_id );
$post = get_post($comment->comment_post_ID);
$authordata = get_userdata($post->post_author);
- $comment_status = wp_get_comment_status($comment->comment_ID);
- if ( 'unapproved' == $comment_status )
- $class .= ' unapproved';
- if ( $alt % 2 )
- $class .= ' alternate';
- echo "
-
-
+
+ $edit
+ $user_object->first_name $user_object->last_name
$email
- $short_url ";
- $r .= "\n\t\t";
+ $role_name ";
+ $r .= "\n\t\t";
if ( $numposts > 0 ) {
$r .= "";
- $r .= sprintf(__ngettext( 'View %s post', 'View %s posts', $numposts ), $numposts);
+ $r .= $numposts;
$r .= '';
- }
- $r .= " \n\t\t";
- if ( ( is_site_admin() || $current_user->ID == $user_object->ID ) && current_user_can( 'edit_user', $user_object->ID ) ) {
- $edit_link = add_query_arg( 'wp_http_referer', urlencode( clean_url( stripslashes( $_SERVER['REQUEST_URI'] ) ) ), "user-edit.php?user_id=$user_object->ID" );
- $r .= "".__( 'Edit' )."";
+ } else {
+ $r .= 0;
}
$r .= " \n\t
| + | ||
| + + + | ||
+
';
}
if (strpos($_SERVER['HTTP_USER_AGENT'], 'MSIE') !== false)
- add_action( 'admin_footer', 'browse_happy' );
+ add_action( 'in_admin_footer', 'browse_happy' );
function the_attachment_links( $id = false ) {
$id = (int) $id;
@@ -560,11 +965,13 @@ function the_attachment_links( $id = false ) {
function wp_dropdown_roles( $default = false ) {
global $wp_roles;
$r = '';
- foreach( array_reverse($wp_roles->role_names) as $role => $name )
+ foreach( $wp_roles->role_names as $role => $name ) {
+ $name = translate_with_context($name);
if ( $default == $role ) // Make default first in list
$p = "\n\t";
else
$r .= "\n\t";
+ }
echo $p . $r;
}
@@ -588,10 +995,15 @@ function wp_convert_bytes_to_hr( $bytes ) {
return $size . $units[$power];
}
-function wp_import_upload_form( $action ) {
+function wp_max_upload_size() {
$u_bytes = wp_convert_hr_to_bytes( ini_get( 'upload_max_filesize' ) );
$p_bytes = wp_convert_hr_to_bytes( ini_get( 'post_max_size' ) );
- $bytes = apply_filters( 'import_upload_size_limit', min($u_bytes, $p_bytes), $u_bytes, $p_bytes );
+ $bytes = apply_filters( 'upload_size_limit', min($u_bytes, $p_bytes), $u_bytes, $p_bytes );
+ return $bytes;
+}
+
+function wp_import_upload_form( $action ) {
+ $bytes = apply_filters( 'import_upload_size_limit', wp_max_upload_size() );
$size = wp_convert_bytes_to_hr( $bytes );
?>
';
}
+/**
+ * add_meta_box() - Add a meta box to an edit form
+ *
+ * @since 2.5
+ *
+ * @param string $id String for use in the 'id' attribute of tags.
+ * @param string $title Title of the meta box
+ * @param string $callback Function that fills the box with the desired content. The function should echo its output.
+ * @param string $page The type of edit page on which to show the box (post, page, link)
+ * @param string $context The context within the page where the boxes should show ('normal', 'advanced')
+ */
+function add_meta_box($id, $title, $callback, $page, $context = 'advanced') {
+ global $wp_meta_boxes;
+
+ if ( !isset($wp_meta_boxes) )
+ $wp_meta_boxes = array();
+ if ( !isset($wp_meta_boxes[$page]) )
+ $wp_meta_boxes[$page] = array();
+ if ( !isset($wp_meta_boxes[$page][$context]) )
+ $wp_meta_boxes[$page][$context] = array();
+
+ $wp_meta_boxes[$page][$context][] = array('id' => $id, 'title' => $title, 'callback' => $callback);
+}
+
+function do_meta_boxes($page, $context, $object) {
+ global $wp_meta_boxes;
+
+ if ( !isset($wp_meta_boxes) || !isset($wp_meta_boxes[$page]) || !isset($wp_meta_boxes[$page][$context]) )
+ return;
+
+ foreach ( (array) $wp_meta_boxes[$page][$context] as $box ) {
+ echo '