Reduced the number of queries in cat_rows and list_cats.
git-svn-id: http://svn.automattic.com/wordpress/trunk@815 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
a644a1018b
commit
28fcfd844d
|
@ -2,40 +2,45 @@
|
||||||
|
|
||||||
|
|
||||||
// Dandy new recursive multiple category stuff.
|
// Dandy new recursive multiple category stuff.
|
||||||
function cat_rows($parent = 0, $level = 0) {
|
function cat_rows($parent = 0, $level = 0, $categories = 0) {
|
||||||
global $wpdb, $tablecategories, $tablepost2cat, $bgcolor;
|
global $wpdb, $tablecategories, $tablepost2cat, $bgcolor;
|
||||||
$categories = $wpdb->get_results("SELECT * FROM $tablecategories WHERE category_parent = $parent ORDER BY cat_name");
|
if (!$categories) {
|
||||||
|
$categories = $wpdb->get_results("SELECT * FROM $tablecategories ORDER BY cat_name");
|
||||||
|
}
|
||||||
if ($categories) {
|
if ($categories) {
|
||||||
foreach ($categories as $category) {
|
foreach ($categories as $category) {
|
||||||
$count = $wpdb->get_var("SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID");
|
if ($category->category_parent == $parent) {
|
||||||
$pad = str_repeat('— ', $level);
|
$count = $wpdb->get_var("SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID");
|
||||||
|
$pad = str_repeat('— ', $level);
|
||||||
|
|
||||||
$bgcolor = ('#eee' == $bgcolor) ? 'none' : '#eee';
|
$bgcolor = ('#eee' == $bgcolor) ? 'none' : '#eee';
|
||||||
echo "<tr style='background-color: $bgcolor'><td>$pad $category->cat_name</td>
|
echo "<tr style='background-color: $bgcolor'><td>$pad $category->cat_name</td>
|
||||||
<td>$category->category_description</td>
|
<td>$category->category_description</td>
|
||||||
<td>$count</td>
|
<td>$count</td>
|
||||||
<td><a href='categories.php?action=edit&cat_ID=$category->cat_ID' class='edit'>Edit</a></td><td><a href='categories.php?action=Delete&cat_ID=$category->cat_ID' onclick=\"return confirm('You are about to delete the category \'". addslashes($category->cat_name) ."\' and all its posts will go to the default category.\\n \'OK\' to delete, \'Cancel\' to stop.')\" class='delete'>Delete</a></td>
|
<td><a href='categories.php?action=edit&cat_ID=$category->cat_ID' class='edit'>Edit</a></td><td><a href='categories.php?action=Delete&cat_ID=$category->cat_ID' onclick=\"return confirm('You are about to delete the category \'". addslashes($category->cat_name) ."\' and all its posts will go to the default category.\\n \'OK\' to delete, \'Cancel\' to stop.')\" class='delete'>Delete</a></td>
|
||||||
</tr>";
|
</tr>";
|
||||||
cat_rows($category->cat_ID, $level + 1);
|
cat_rows($category->cat_ID, $level + 1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function wp_dropdown_cats($currentcat, $currentparent = 0, $parent = 0, $level = 0) {
|
function wp_dropdown_cats($currentcat, $currentparent = 0, $parent = 0, $level = 0, $categories = 0) {
|
||||||
global $wpdb, $tablecategories, $tablepost2cat, $bgcolor;
|
global $wpdb, $tablecategories, $tablepost2cat, $bgcolor;
|
||||||
$categories = $wpdb->get_results("SELECT * FROM $tablecategories WHERE category_parent = $parent ORDER BY cat_name");
|
if (!$categories) {
|
||||||
|
$categories = $wpdb->get_results("SELECT * FROM $tablecategories ORDER BY cat_name");
|
||||||
|
}
|
||||||
if ($categories) {
|
if ($categories) {
|
||||||
foreach ($categories as $category) { if ($currentcat != $category->cat_ID) {
|
foreach ($categories as $category) { if ($currentcat != $category->cat_ID && $parent == $category->category_parent) {
|
||||||
$count = $wpdb->get_var("SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID");
|
$count = $wpdb->get_var("SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID");
|
||||||
$pad = str_repeat('– ', $level);
|
$pad = str_repeat('– ', $level);
|
||||||
echo "\n\t<option value='$category->cat_ID'";
|
echo "\n\t<option value='$category->cat_ID'";
|
||||||
if ($currentparent == $category->cat_ID)
|
if ($currentparent == $category->cat_ID)
|
||||||
echo " selected='selected'";
|
echo " selected='selected'";
|
||||||
echo ">$pad$category->cat_name</option>";
|
echo ">$pad$category->cat_name</option>";
|
||||||
if ($currentcat != $category->cat_ID)
|
wp_dropdown_cats($currentcat, $currentparent, $category->cat_ID, $level + 1, $categories);
|
||||||
wp_dropdown_cats($currentcat, $currentparent, $category->cat_ID, $level + 1);
|
|
||||||
} }
|
} }
|
||||||
} else {
|
} else {
|
||||||
return false;
|
return false;
|
||||||
|
|
Loading…
Reference in New Issue