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,11 +2,14 @@
|
|||
|
||||
|
||||
// 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;
|
||||
$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) {
|
||||
foreach ($categories as $category) {
|
||||
if ($category->category_parent == $parent) {
|
||||
$count = $wpdb->get_var("SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID");
|
||||
$pad = str_repeat('— ', $level);
|
||||
|
||||
|
@ -18,24 +21,26 @@ function cat_rows($parent = 0, $level = 0) {
|
|||
</tr>";
|
||||
cat_rows($category->cat_ID, $level + 1);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
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;
|
||||
$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) {
|
||||
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");
|
||||
$pad = str_repeat('– ', $level);
|
||||
echo "\n\t<option value='$category->cat_ID'";
|
||||
if ($currentparent == $category->cat_ID)
|
||||
echo " selected='selected'";
|
||||
echo ">$pad$category->cat_name</option>";
|
||||
if ($currentcat != $category->cat_ID)
|
||||
wp_dropdown_cats($currentcat, $currentparent, $category->cat_ID, $level + 1);
|
||||
wp_dropdown_cats($currentcat, $currentparent, $category->cat_ID, $level + 1, $categories);
|
||||
} }
|
||||
} else {
|
||||
return false;
|
||||
|
|
Loading…
Reference in New Issue