2003-05-22 08:12:53 -04:00
< ? php
2004-04-22 19:32:34 -04:00
require_once ( '../wp-includes/wp-l10n.php' );
$title = __ ( 'Categories' );
2004-08-22 19:24:50 -04:00
$parent_file = 'edit.php' ;
2003-05-22 08:12:53 -04:00
function add_magic_quotes ( $array ) {
2004-01-27 01:35:07 -05:00
foreach ( $array as $k => $v ) {
if ( is_array ( $v )) {
$array [ $k ] = add_magic_quotes ( $v );
} else {
$array [ $k ] = addslashes ( $v );
}
}
return $array ;
}
2003-05-22 08:12:53 -04:00
if ( ! get_magic_quotes_gpc ()) {
2004-04-20 18:56:47 -04:00
$_GET = add_magic_quotes ( $_GET );
$_POST = add_magic_quotes ( $_POST );
$_COOKIE = add_magic_quotes ( $_COOKIE );
2003-05-22 08:12:53 -04:00
}
2003-12-18 04:36:13 -05:00
$wpvarstoreset = array ( 'action' , 'standalone' , 'cat' );
for ( $i = 0 ; $i < count ( $wpvarstoreset ); $i += 1 ) {
2004-01-27 01:35:07 -05:00
$wpvar = $wpvarstoreset [ $i ];
if ( ! isset ( $$wpvar )) {
2004-04-20 18:56:47 -04:00
if ( empty ( $_POST [ " $wpvar " ])) {
if ( empty ( $_GET [ " $wpvar " ])) {
2004-01-27 01:35:07 -05:00
$$wpvar = '' ;
} else {
2004-04-20 18:56:47 -04:00
$$wpvar = $_GET [ " $wpvar " ];
2004-01-27 01:35:07 -05:00
}
} else {
2004-04-20 18:56:47 -04:00
$$wpvar = $_POST [ " $wpvar " ];
2004-01-27 01:35:07 -05:00
}
}
2003-05-22 08:12:53 -04:00
}
switch ( $action ) {
2003-05-23 04:29:51 -04:00
case 'addcat' :
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
$standalone = 1 ;
require_once ( 'admin-header.php' );
if ( $user_level < 3 )
2004-04-22 19:32:34 -04:00
die ( __ ( 'Cheatin’ uh?' ));
2004-01-27 01:35:07 -05:00
2004-07-23 23:55:31 -04:00
$cat_name = $_POST [ 'cat_name' ];
2004-07-23 23:39:21 -04:00
$cat_ID = $wpdb -> get_var ( " SELECT cat_ID FROM $wpdb->categories ORDER BY cat_ID DESC LIMIT 1 " ) + 1 ;
$category_nicename = sanitize_title ( $cat_name , $cat_ID );
2004-07-23 23:55:31 -04:00
$category_description = $_POST [ 'category_description' ];
2004-04-20 18:56:47 -04:00
$cat = intval ( $_POST [ 'cat' ]);
2004-03-10 14:46:48 -05:00
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " INSERT INTO $wpdb->categories (cat_ID, cat_name, category_nicename, category_description, category_parent) VALUES ('0', ' $cat_name ', ' $category_nicename ', ' $category_description ', ' $cat ') " );
2004-01-27 01:35:07 -05:00
2004-04-28 01:48:31 -04:00
header ( 'Location: categories.php?message=1#addcat' );
2003-05-22 08:12:53 -04:00
break ;
2003-05-23 04:29:51 -04:00
case 'Delete' :
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
$standalone = 1 ;
require_once ( 'admin-header.php' );
2003-05-22 08:12:53 -04:00
2004-05-17 15:44:53 -04:00
check_admin_referer ();
2004-04-20 18:56:47 -04:00
$cat_ID = intval ( $_GET [ " cat_ID " ]);
2004-01-27 01:35:07 -05:00
$cat_name = get_catname ( $cat_ID );
2004-05-24 04:22:18 -04:00
$category = $wpdb -> get_row ( " SELECT * FROM $wpdb->categories WHERE cat_ID = ' $cat_ID ' " );
2004-02-10 18:39:08 -05:00
$cat_parent = $category -> category_parent ;
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
if ( 1 == $cat_ID )
2004-04-22 19:32:34 -04:00
die ( sprintf ( __ ( " Can't delete the <strong>%s</strong> category: this is the default one " ), $cat_name ));
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
if ( $user_level < 3 )
2004-04-22 19:32:34 -04:00
die ( __ ( 'Cheatin’ uh?' ));
2003-07-30 19:44:08 -04:00
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " DELETE FROM $wpdb->categories WHERE cat_ID = ' $cat_ID ' " );
$wpdb -> query ( " UPDATE $wpdb->categories SET category_parent = ' $cat_parent ' WHERE category_parent = ' $cat_ID ' " );
$wpdb -> query ( " UPDATE $wpdb->post2cat SET category_id='1' WHERE category_id=' $cat_ID ' " );
2003-05-22 08:12:53 -04:00
2004-04-28 01:48:31 -04:00
header ( 'Location: categories.php?message=2' );
2003-05-22 08:12:53 -04:00
break ;
2003-12-07 05:38:25 -05:00
case 'edit' :
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
require_once ( 'admin-header.php' );
2004-05-17 10:53:22 -04:00
$cat_ID = intval ( $_GET [ 'cat_ID' ]);
2004-05-24 04:22:18 -04:00
$category = $wpdb -> get_row ( " SELECT * FROM $wpdb->categories WHERE cat_ID = ' $cat_ID ' " );
2004-07-23 23:55:31 -04:00
$cat_name = $category -> cat_name ;
2004-01-27 01:35:07 -05:00
?>
2004-08-22 19:24:50 -04:00
2003-05-23 04:29:51 -04:00
< div class = " wrap " >
2004-04-22 19:32:34 -04:00
< h2 >< ? php _e ( 'Edit Category' ) ?> </h2>
2004-01-27 01:35:07 -05:00
< form name = " editcat " action = " categories.php " method = " post " >
< input type = " hidden " name = " action " value = " editedcat " />
2004-04-20 18:56:47 -04:00
< input type = " hidden " name = " cat_ID " value = " <?php echo $_GET['cat_ID'] ?> " />
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Category name:' ) ?> <br />
2004-06-18 23:57:57 -04:00
< input type = " text " name = " cat_name " value = " <?php echo htmlspecialchars( $cat_name ); ?> " /></ p >
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Category parent:' ) ?> <br />
2004-01-30 01:22:55 -05:00
< select name = 'cat' class = 'postform' >
2004-05-23 13:24:38 -04:00
< option value = '0' < ? php if ( ! $category -> category_parent ) echo " selected='selected' " ; ?> ><?php _e('None') ?></option>
2004-06-11 14:23:12 -04:00
< ? php wp_dropdown_cats ( $category -> cat_ID , $category -> category_parent ); ?>
2004-01-30 01:22:55 -05:00
</ select >
2004-01-27 03:31:17 -05:00
</ p >
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Description:' ) ?> <br />
2004-05-18 11:24:23 -04:00
< textarea name = " category_description " rows = " 5 " cols = " 50 " style = " width: 97%; " >< ? php echo htmlspecialchars ( $category -> category_description , ENT_NOQUOTES ); ?> </textarea></p>
2004-04-28 01:48:31 -04:00
< p class = " submit " >< input type = " submit " name = " submit " value = " <?php _e('Edit category »') ?> " /></ p >
2004-01-27 01:35:07 -05:00
</ form >
2003-05-23 04:29:51 -04:00
</ div >
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
< ? php
2003-05-22 08:12:53 -04:00
break ;
2003-05-23 04:29:51 -04:00
case 'editedcat' :
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
$standalone = 1 ;
require_once ( 'admin-header.php' );
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
if ( $user_level < 3 )
2004-04-22 19:32:34 -04:00
die ( __ ( 'Cheatin’ uh?' ));
2004-01-27 01:35:07 -05:00
2004-07-23 23:55:31 -04:00
$cat_name = $_POST [ 'cat_name' ];
2004-04-27 09:24:47 -04:00
$cat_ID = ( int ) $_POST [ 'cat_ID' ];
2004-07-23 23:39:21 -04:00
$category_nicename = sanitize_title ( $cat_name , $cat_ID );
2004-07-23 23:55:31 -04:00
$category_description = $_POST [ 'category_description' ];
2003-05-22 08:12:53 -04:00
2004-05-24 04:22:18 -04:00
$wpdb -> query ( " UPDATE $wpdb->categories SET cat_name = ' $cat_name ', category_nicename = ' $category_nicename ', category_description = ' $category_description ', category_parent = ' $cat ' WHERE cat_ID = ' $cat_ID ' " );
2004-01-27 01:35:07 -05:00
2004-04-28 01:48:31 -04:00
header ( 'Location: categories.php?message=3' );
2003-05-22 08:12:53 -04:00
break ;
default :
2004-01-27 01:35:07 -05:00
$standalone = 0 ;
require_once ( 'admin-header.php' );
if ( $user_level < 3 ) {
2004-04-22 19:32:34 -04:00
die ( sprintf ( __ ( " You have no right to edit the categories for this blog.<br />Ask for a promotion to your <a href='mailto:%s'>blog admin</a>. :) " ), get_settings ( 'admin_email' )));
2004-01-27 01:35:07 -05:00
}
2004-04-28 01:48:31 -04:00
$messages [ 1 ] = __ ( 'Category added.' );
$messages [ 2 ] = __ ( 'Category deleted.' );
$messages [ 3 ] = __ ( 'Category updated.' );
?>
2004-08-22 19:24:50 -04:00
2004-05-07 19:56:33 -04:00
< ? php if ( isset ( $_GET [ 'message' ])) : ?>
2004-04-28 01:48:31 -04:00
< div class = " updated " >< p >< ? php echo $messages [ $_GET [ 'message' ]]; ?> </p></div>
< ? php endif ; ?>
2003-12-27 15:55:03 -05:00
2004-01-29 21:26:22 -05:00
< div class = " wrap " >
2004-04-22 19:32:34 -04:00
< h2 >< ? php printf ( __ ( 'Current Categories (<a href="%s">add new</a>)' ), '#addcat' ) ?> </h2>
2004-01-29 21:26:22 -05:00
< table width = " 100% " cellpadding = " 3 " cellspacing = " 3 " >
< tr >
2004-04-24 15:32:31 -04:00
< th scope = " col " >< ? php _e ( 'ID' ) ?> </th>
2004-04-22 19:32:34 -04:00
< th scope = " col " >< ? php _e ( 'Name' ) ?> </th>
< th scope = " col " >< ? php _e ( 'Description' ) ?> </th>
< th scope = " col " >< ? php _e ( '# Posts' ) ?> </th>
< th colspan = " 2 " >< ? php _e ( 'Action' ) ?> </th>
2004-01-29 21:26:22 -05:00
</ tr >
< ? php
cat_rows ();
?>
</ table >
</ div >
2003-05-22 08:12:53 -04:00
2004-01-27 01:35:07 -05:00
< div class = " wrap " >
2004-04-22 19:32:34 -04:00
< p >< ? php printf ( __ ( ' < 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 >% s </ strong >. ' ), get_catname ( 1 )) ?>
2003-05-23 04:29:51 -04:00
</ p >
</ div >
2003-05-22 08:12:53 -04:00
2004-01-30 01:22:55 -05:00
< div class = " wrap " >
2004-04-22 19:32:34 -04:00
< h2 >< ? php _e ( 'Add New Category' ) ?> </h2>
2004-01-30 01:22:55 -05:00
< form name = " addcat " id = " addcat " action = " categories.php " method = " post " >
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Name:' ) ?> <br />
2004-01-30 01:22:55 -05:00
< input type = " text " name = " cat_name " value = " " /></ p >
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Category parent:' ) ?> <br />
2004-01-30 01:22:55 -05:00
< select name = 'cat' class = 'postform' >
2004-04-22 19:32:34 -04:00
< option value = '0' >< ? php _e ( 'None' ) ?> </option>
2004-06-11 14:23:12 -04:00
< ? php wp_dropdown_cats ( 0 ); ?>
</ select ></ p >
2004-04-22 19:32:34 -04:00
< p >< ? php _e ( 'Description: (optional)' ) ?> <br />
2004-01-30 01:22:55 -05:00
< textarea name = " category_description " rows = " 5 " cols = " 50 " style = " width: 97%; " ></ textarea ></ p >
2004-04-28 01:48:31 -04:00
< p class = " submit " >< input type = " hidden " name = " action " value = " addcat " />< input type = " submit " name = " submit " value = " <?php _e('Add Category »') ?> " /></ p >
2004-01-30 01:22:55 -05:00
</ form >
</ div >
2004-01-27 01:35:07 -05:00
< ? php
2003-05-22 08:12:53 -04:00
break ;
}
2003-12-10 19:22:36 -05:00
include ( 'admin-footer.php' );
2004-01-30 01:22:55 -05:00
?>