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