2003-05-22 14:12:53 +02:00
< ? php
2003-05-23 10:29:51 +02:00
$title = 'Categories' ;
2003-05-22 14:12:53 +02:00
/* <Categories> */
function add_magic_quotes ( $array ) {
foreach ( $array as $k => $v ) {
if ( is_array ( $v )) {
$array [ $k ] = add_magic_quotes ( $v );
} else {
$array [ $k ] = addslashes ( $v );
}
}
return $array ;
}
if ( ! get_magic_quotes_gpc ()) {
$HTTP_GET_VARS = add_magic_quotes ( $HTTP_GET_VARS );
$HTTP_POST_VARS = add_magic_quotes ( $HTTP_POST_VARS );
$HTTP_COOKIE_VARS = add_magic_quotes ( $HTTP_COOKIE_VARS );
}
2003-12-18 10:36:13 +01:00
$wpvarstoreset = array ( 'action' , 'standalone' , 'cat' );
for ( $i = 0 ; $i < count ( $wpvarstoreset ); $i += 1 ) {
$wpvar = $wpvarstoreset [ $i ];
if ( ! isset ( $$wpvar )) {
if ( empty ( $HTTP_POST_VARS [ " $wpvar " ])) {
if ( empty ( $HTTP_GET_VARS [ " $wpvar " ])) {
$$wpvar = '' ;
2003-05-22 14:12:53 +02:00
} else {
2003-12-18 10:36:13 +01:00
$$wpvar = $HTTP_GET_VARS [ " $wpvar " ];
2003-05-22 14:12:53 +02:00
}
} else {
2003-12-18 10:36:13 +01:00
$$wpvar = $HTTP_POST_VARS [ " $wpvar " ];
2003-05-22 14:12:53 +02:00
}
}
}
switch ( $action ) {
2003-05-23 10:29:51 +02:00
case 'addcat' :
2003-05-22 14:12:53 +02:00
$standalone = 1 ;
2003-12-11 01:22:36 +01:00
require_once ( 'admin-header.php' );
2003-12-07 10:37:27 +01:00
2003-05-22 14:12:53 +02:00
if ( $user_level < 3 )
2003-05-23 10:29:51 +02:00
die ( 'Cheatin’ uh?' );
2003-05-22 14:12:53 +02:00
2003-12-07 10:37:27 +01:00
$cat_name = addslashes ( stripslashes ( stripslashes ( $HTTP_POST_VARS [ 'cat_name' ])));
$category_nicename = sanitize_title ( $cat_name );
2003-12-07 11:53:46 +01:00
$category_description = addslashes ( stripslashes ( stripslashes ( $HTTP_POST_VARS [ 'category_description' ])));
2003-05-22 14:12:53 +02:00
2003-12-07 11:53:46 +01:00
$wpdb -> query ( " INSERT INTO $tablecategories (cat_ID, cat_name, category_nicename, category_description) VALUES ('0', ' $cat_name ', ' $category_nicename ', ' $category_description ') " );
2003-12-07 10:37:27 +01:00
header ( 'Location: categories.php' );
2003-05-22 14:12:53 +02:00
break ;
2003-05-23 10:29:51 +02:00
case 'Delete' :
2003-05-22 14:12:53 +02:00
$standalone = 1 ;
2003-12-11 01:22:36 +01:00
require_once ( 'admin-header.php' );
2003-05-22 14:12:53 +02:00
2003-12-07 11:38:25 +01:00
$cat_ID = intval ( $HTTP_GET_VARS [ " cat_ID " ]);
2003-05-23 10:29:51 +02:00
$cat_name = get_catname ( $cat_ID );
$cat_name = addslashes ( $cat_name );
2003-05-22 14:12:53 +02:00
2003-05-23 10:29:51 +02:00
if ( 1 == $cat_ID )
die ( " Can't delete the <strong> $cat_name </strong> category: this is the default one " );
2003-05-22 14:12:53 +02:00
if ( $user_level < 3 )
2003-05-23 10:29:51 +02:00
die ( 'Cheatin’ uh?' );
2003-07-31 01:44:08 +02:00
$wpdb -> query ( " DELETE FROM $tablecategories WHERE cat_ID = $cat_ID " );
2003-12-07 10:37:27 +01:00
$wpdb -> query ( " UPDATE $tablepost2cat SET category_id='1' WHERE category_id=' $cat_ID ' " );
2003-05-22 14:12:53 +02:00
2003-12-07 10:37:27 +01:00
header ( 'Location: categories.php' );
2003-05-22 14:12:53 +02:00
break ;
2003-12-07 11:38:25 +01:00
case 'edit' :
2003-05-22 14:12:53 +02:00
2003-12-11 01:22:36 +01:00
require_once ( 'admin-header.php' );
2003-12-07 11:38:25 +01:00
$category = $wpdb -> get_row ( " SELECT * FROM $tablecategories WHERE cat_ID = " . $HTTP_GET_VARS [ 'cat_ID' ]);
$cat_name = stripslashes ( $category -> cat_name );
2003-05-22 14:12:53 +02:00
?>
2003-05-23 10:29:51 +02:00
< div class = " wrap " >
2003-12-07 11:38:25 +01:00
< h2 > Edit Category </ h2 >
< form name = " editcat " action = " categories.php " method = " post " >
2003-05-22 14:12:53 +02:00
< input type = " hidden " name = " action " value = " editedcat " />
2003-12-07 11:38:25 +01:00
< input type = " hidden " name = " cat_ID " value = " <?php echo $HTTP_GET_VARS['cat_ID'] ?> " />
< p > Category name :< br />
< input type = " text " name = " cat_name " value = " <?php echo $cat_name ; ?> " /></ p >
< p > Description :< br />
< textarea name = " category_description " rows = " 5 " cols = " 50 " style = " width: 97%; " >< ? php echo htmlentities ( $category -> category_description ); ?> </textarea></p>
< p >< input type = " submit " name = " submit " value = " Edit it! " class = " search " /></ p >
2003-05-22 14:12:53 +02:00
</ form >
2003-05-23 10:29:51 +02:00
</ div >
2003-05-22 14:12:53 +02:00
< ? php
break ;
2003-05-23 10:29:51 +02:00
case 'editedcat' :
2003-05-22 14:12:53 +02:00
$standalone = 1 ;
2003-12-11 01:22:36 +01:00
require_once ( 'admin-header.php' );
2003-05-22 14:12:53 +02:00
if ( $user_level < 3 )
2003-05-23 10:29:51 +02:00
die ( 'Cheatin’ uh?' );
2003-05-22 14:12:53 +02:00
2003-12-07 10:37:27 +01:00
$cat_name = addslashes ( stripslashes ( stripslashes ( $HTTP_POST_VARS [ 'cat_name' ])));
$cat_ID = addslashes ( $HTTP_POST_VARS [ 'cat_ID' ]);
$category_nicename = sanitize_title ( $cat_name );
2003-12-07 11:38:25 +01:00
$category_description = $HTTP_POST_VARS [ 'category_description' ];
2003-05-22 14:12:53 +02:00
2003-12-07 11:38:25 +01:00
$wpdb -> query ( " UPDATE $tablecategories SET cat_name = ' $cat_name ', category_nicename = ' $category_nicename ', category_description = ' $category_description ' WHERE cat_ID = $cat_ID " );
2003-05-22 14:12:53 +02:00
2003-12-07 10:37:27 +01:00
header ( 'Location: categories.php' );
2003-05-22 14:12:53 +02:00
break ;
default :
2003-05-23 10:29:51 +02:00
$standalone = 0 ;
2003-12-11 01:22:36 +01:00
require_once ( 'admin-header.php' );
2003-05-22 14:12:53 +02:00
if ( $user_level < 3 ) {
2003-05-23 10:29:51 +02:00
die ( " You have no right to edit the categories for this blog.<br />Ask for a promotion to your <a href='mailto: $admin_email '>blog admin</a>. :) " );
2003-05-22 14:12:53 +02:00
}
?>
2003-12-07 11:47:09 +01:00
< style type = " text/css " >
. edit , . delete , . edit : hover , . delete : hover {
display : block ;
text - align : center ;
border - bottom : none ;
}
. edit : hover {
background - color : #ccc;
color : #fff;
}
. delete : hover {
background - color : #c00;
color : #fff;
}
</ style >
2003-05-23 10:29:51 +02:00
< div class = " wrap " >
2003-12-07 11:38:25 +01:00
< h2 > Current Categories </ h2 >
2003-12-08 04:46:42 +01:00
< table width = " 100% " cellpadding = " 3 " cellspacing = " 3 " >
2003-12-07 11:38:25 +01:00
< tr >
2003-12-07 11:47:09 +01:00
< th scope = " col " > Name </ th >
< th scope = " col " > Description </ th >
< th scope = " col " > # Posts</th>
< th colspan = " 2 " > Action </ th >
2003-12-07 11:38:25 +01:00
</ tr >
2003-05-22 14:12:53 +02:00
< ? php
2003-12-07 11:38:25 +01:00
$categories = $wpdb -> get_results ( " SELECT * FROM $tablecategories ORDER BY cat_name " );
2003-06-01 13:43:30 +02:00
foreach ( $categories as $category ) {
2003-12-07 11:38:25 +01:00
$count = $wpdb -> get_var ( " SELECT COUNT(post_id) FROM $tablepost2cat WHERE category_id = $category->cat_ID " );
2003-12-07 11:47:09 +01:00
$bgcolor = ( '#eee' == $bgcolor ) ? 'none' : '#eee' ;
echo " <tr style='background-color: $bgcolor '><td> $category->cat_name </td>
2003-12-07 11:38:25 +01:00
< td > $category -> category_description </ td >
< td > $count </ td >
2003-12-07 11:53:46 +01:00
< 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>
2003-12-07 11:38:25 +01:00
</ tr > " ;
2003-05-22 14:12:53 +02:00
}
2003-12-07 11:38:25 +01:00
?>
</ table >
</ div >
< div class = " wrap " >
< h2 > Add New Category </ h2 >
2003-12-07 10:37:27 +01:00
< form name = " addcat " action = " categories.php " method = " post " >
2003-12-07 11:38:25 +01:00
2003-12-07 11:47:09 +01:00
< p > Name :< br />
2003-12-07 11:38:25 +01:00
< input type = " text " name = " cat_name " value = " " /></ p >
2003-12-08 02:28:41 +01:00
< p > Description : ( optional ) < br />
2003-12-07 11:38:25 +01:00
< textarea name = " category_description " rows = " 5 " cols = " 50 " style = " width: 97%; " ></ textarea ></ p >
< p >< input type = " hidden " name = " action " value = " addcat " />< input type = " submit " name = " submit " value = " Add " class = " search " /></ p >
2003-05-22 14:12:53 +02:00
</ form >
2003-05-23 10:29:51 +02:00
</ div >
2003-05-22 14:12:53 +02:00
2003-05-23 10:29:51 +02:00
< div class = " wrap " >
< p >< strong > Note :</ strong >< br />
Deleting a category does not delete posts from that category , it will just
set them back to the default category < strong >< ? php echo get_catname ( 1 ) ?> </strong>.
</ p >
</ div >
2003-05-22 14:12:53 +02:00
< ? php
break ;
}
/* </Categories> */
2003-12-11 01:22:36 +01:00
include ( 'admin-footer.php' );
2003-05-23 10:29:51 +02:00
?>