Fix for bug #0000048: nested categories now display correctly in admin regardless of the order of their IDs

git-svn-id: http://svn.automattic.com/wordpress/trunk@1432 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
jverber 2004-06-16 16:40:40 +00:00
parent 0c388147a9
commit 14a8ab9fc0
1 changed files with 52 additions and 12 deletions

View File

@ -18,7 +18,41 @@ function checked($checked, $current) {
if ($checked == $current) echo ' checked="checked"'; if ($checked == $current) echo ' checked="checked"';
} }
function get_nested_categories($default = 0) { function return_categories_list( $parent = 0, $sortbyname = FALSE )
{
/*
* This function returns an list of all categories
* that have $parent as their parent
* if no parent is specified we will assume top level caegories
* are required.
*/
global $wpdb;
// select sort order
$sort = "cat_id";
if( TRUE == $sortbyname )
{
$sort = "cat_name";
}
// First query the database
$cats_tmp = $wpdb->get_results("SELECT cat_id FROM $wpdb->categories WHERE category_parent = $parent ORDER BY $sort");
// Now strip this down to a simple array of IDs
$cats = array();
if( count($cats_tmp) > 0 )
{
foreach( $cats_tmp as $cat )
{
$cats[] = $cat->cat_id;
}
}
// Return the list of categories
return $cats;
}
function get_nested_categories($default = 0, $parent = 0) {
global $post_ID, $mode, $wpdb; global $post_ID, $mode, $wpdb;
if ($post_ID) { if ($post_ID) {
@ -27,23 +61,29 @@ function get_nested_categories($default = 0) {
FROM $wpdb->categories, $wpdb->post2cat FROM $wpdb->categories, $wpdb->post2cat
WHERE $wpdb->post2cat.category_id = cat_ID AND $wpdb->post2cat.post_id = '$post_ID' WHERE $wpdb->post2cat.category_id = cat_ID AND $wpdb->post2cat.post_id = '$post_ID'
"); ");
if(count($checked_categories) == 0)
{
// No selected categories, strange
$checked_categories[] = $default;
}
} else { } else {
$checked_categories[] = $default; $checked_categories[] = $default;
} }
$categories = $wpdb->get_results("SELECT * FROM $wpdb->categories ORDER BY category_parent DESC, cat_name ASC"); $cats = return_categories_list($parent, TRUE);
$result = array(); $result = array();
foreach($categories as $category) {
$array_category = get_object_vars($category); foreach($cats as $cat)
$me = 0 + $category->cat_ID; {
$parent = 0 + $category->category_parent; $result[$cat]['children'] = get_nested_categories($default, $cat);
if (isset($result[$me])) $array_category['children'] = $result[$me]; $result[$cat]['cat_ID'] = $cat;
$array_category['checked'] = in_array($category->cat_ID, $checked_categories); $result[$cat]['checked'] = in_array($cat, $checked_categories);
$array_category['cat_name'] = stripslashes($category->cat_name); $result[$cat]['cat_name'] = stripslashes(get_the_category_by_ID($cat));
$result[$parent][] = $array_category;
} }
return $result[0]; return $result;
} }
function write_nested_categories($categories) { function write_nested_categories($categories) {