2004-09-11 18:12:40 +02:00
< ? php
2004-10-19 05:03:06 +02:00
require_once ( 'admin.php' );
2006-11-18 08:31:29 +01:00
$title = __ ( " Edit Themes " );
$parent_file = 'themes.php' ;
2006-07-03 21:03:37 +02:00
wp_reset_vars ( array ( 'action' , 'redirect' , 'profile' , 'error' , 'warning' , 'a' , 'file' , 'theme' ));
2004-09-11 18:12:40 +02:00
2004-11-17 04:15:44 +01:00
$themes = get_themes ();
if ( empty ( $theme )) {
$theme = get_current_theme ();
2005-02-26 07:38:18 +01:00
} else {
$theme = stripslashes ( $theme );
2005-04-19 23:41:35 +02:00
}
if ( ! isset ( $themes [ $theme ]) )
2006-07-06 00:00:03 +02:00
wp_die ( __ ( 'The requested theme does not exist.' ));
2004-11-17 04:15:44 +01:00
2004-11-23 18:51:34 +01:00
$allowed_files = array_merge ( $themes [ $theme ][ 'Stylesheet Files' ], $themes [ $theme ][ 'Template Files' ]);
2004-11-17 04:15:44 +01:00
if ( empty ( $file )) {
$file = $allowed_files [ 0 ];
}
$file = validate_file_to_edit ( $file , $allowed_files );
$real_file = get_real_file_to_edit ( $file );
2005-11-14 11:26:39 +01:00
$file_show = basename ( $file );
2004-09-11 18:12:40 +02:00
switch ( $action ) {
case 'update' :
2006-05-27 01:08:05 +02:00
check_admin_referer ( 'edit-theme_' . $file . $theme );
2006-03-31 01:12:54 +02:00
2005-07-15 04:16:45 +02:00
if ( ! current_user_can ( 'edit_themes' ) )
2006-07-06 00:00:03 +02:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit templates for this blog.' ) . '</p>' );
2004-09-11 18:12:40 +02:00
$newcontent = stripslashes ( $_POST [ 'newcontent' ]);
2004-11-25 17:15:27 +01:00
$theme = urlencode ( $theme );
2004-11-17 04:15:44 +01:00
if ( is_writeable ( $real_file )) {
$f = fopen ( $real_file , 'w+' );
fwrite ( $f , $newcontent );
fclose ( $f );
2006-10-02 21:26:12 +02:00
$location = " theme-editor.php?file= $file &theme= $theme &a=te " ;
2004-11-17 04:15:44 +01:00
} else {
2006-10-02 21:26:12 +02:00
$location = " theme-editor.php?file= $file &theme= $theme " ;
2004-11-17 04:15:44 +01:00
}
2004-09-11 18:12:40 +02:00
2006-10-02 21:26:12 +02:00
$location = wp_kses_no_null ( $location );
$strip = array ( '%0d' , '%0a' );
$location = str_replace ( $strip , '' , $location );
header ( " Location: $location " );
2004-09-11 18:12:40 +02:00
exit ();
break ;
default :
2006-02-12 08:53:23 +01:00
2005-07-15 04:16:45 +02:00
if ( ! current_user_can ( 'edit_themes' ) )
2006-07-06 00:00:03 +02:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit themes for this blog.' ) . '</p>' );
2004-09-11 18:12:40 +02:00
2006-08-22 20:20:00 +02:00
require_once ( 'admin-header.php' );
2004-11-17 04:15:44 +01:00
update_recently_edited ( $file );
2006-02-12 08:53:23 +01:00
2004-09-11 18:12:40 +02:00
if ( ! is_file ( $real_file ))
$error = 1 ;
2006-02-12 08:53:23 +01:00
2005-03-15 23:25:40 +01:00
if ( ! $error && filesize ( $real_file ) > 0 ) {
2004-09-11 18:12:40 +02:00
$f = fopen ( $real_file , 'r' );
$content = fread ( $f , filesize ( $real_file ));
2005-01-24 00:00:15 +01:00
$content = htmlspecialchars ( $content );
2004-09-11 18:12:40 +02:00
}
?>
< ? php if ( isset ( $_GET [ 'a' ])) : ?>
2005-08-08 03:13:22 +02:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'File edited successfully.' ) ?> </p></div>
2004-09-11 18:12:40 +02:00
< ? php endif ; ?>
< div class = " wrap " >
2006-11-19 08:56:05 +01:00
< form name = " theme " action = " theme-editor.php " method = " post " >
2004-09-11 18:12:40 +02:00
< ? php _e ( 'Select theme to edit:' ) ?>
< select name = " theme " id = " theme " >
< ? php
foreach ( $themes as $a_theme ) {
$theme_name = $a_theme [ 'Name' ];
if ( $theme_name == $theme ) $selected = " selected='selected' " ;
else $selected = '' ;
2006-12-21 11:10:04 +01:00
$theme_name = attribute_escape ( $theme_name );
2005-02-26 07:38:18 +01:00
echo " \n \t <option value= \" $theme_name\ " $selected > $theme_name </ option > " ;
2004-09-11 18:12:40 +02:00
}
?>
</ select >
2006-10-06 03:14:47 +02:00
< input type = " submit " name = " Submit " value = " <?php _e('Select »') ?> " class = " button " />
2004-09-11 18:12:40 +02:00
</ form >
</ div >
2007-09-04 01:32:58 +02:00
< div class = " wrap " >
2004-09-11 18:12:40 +02:00
< ? php
2005-11-14 11:26:39 +01:00
if ( is_writeable ( $real_file ) ) {
echo '<h2>' . sprintf ( __ ( 'Editing <code>%s</code>' ), $file_show ) . '</h2>' ;
2004-11-17 04:15:44 +01:00
} else {
2005-11-14 11:26:39 +01:00
echo '<h2>' . sprintf ( __ ( 'Browsing <code>%s</code>' ), $file_show ) . '</h2>' ;
2004-11-17 04:15:44 +01:00
}
?>
< div id = " templateside " >
2006-11-19 08:56:05 +01:00
< h3 >< ? php printf ( __ ( " <strong>'%s'</strong> theme files " ), $theme ) ?> </h3>
2004-11-17 04:15:44 +01:00
< ? php
if ( $allowed_files ) :
?>
2006-11-19 08:56:05 +01:00
< ul >
2004-11-17 04:15:44 +01:00
< ? php foreach ( $allowed_files as $allowed_file ) : ?>
2005-02-14 05:24:25 +01:00
< li >< a href = " theme-editor.php?file=<?php echo " $allowed_file " ; ?>&theme=<?php echo urlencode( $theme ) ?> " >< ? php echo get_file_description ( $allowed_file ); ?> </a></li>
2004-11-17 04:15:44 +01:00
< ? php endforeach ; ?>
2006-11-19 08:56:05 +01:00
</ ul >
2004-11-17 04:15:44 +01:00
< ? php endif ; ?>
2006-11-19 08:56:05 +01:00
</ div >
2004-11-17 04:15:44 +01:00
< ? php
2004-09-11 18:12:40 +02:00
if ( ! $error ) {
2006-11-19 08:56:05 +01:00
?>
< form name = " template " id = " template " action = " theme-editor.php " method = " post " >
< ? php wp_nonce_field ( 'edit-theme_' . $file . $theme ) ?>
< div >< textarea cols = " 70 " rows = " 25 " name = " newcontent " id = " newcontent " tabindex = " 1 " >< ? php echo $content ?> </textarea>
< input type = " hidden " name = " action " value = " update " />
< input type = " hidden " name = " file " value = " <?php echo $file ?> " />
< input type = " hidden " name = " theme " value = " <?php echo $theme ?> " />
2004-11-17 04:15:44 +01:00
</ div >
< ? php if ( is_writeable ( $real_file ) ) : ?>
2006-11-19 08:56:05 +01:00
< p class = " submit " >
2004-11-17 04:15:44 +01:00
< ? php
2006-02-17 02:29:33 +01:00
echo " <input type='submit' name='submit' value=' " . __ ( 'Update File »' ) . " ' tabindex='2' /> " ;
2004-11-17 04:15:44 +01:00
?>
2004-09-11 18:12:40 +02:00
</ p >
2004-11-17 04:15:44 +01:00
< ? php else : ?>
2008-02-09 21:17:49 +01:00
< p >< em >< ? php _e ( 'You need to make this file writable before you can save your changes. See <a href="http://codex.wordpress.org/Changing_File_Permissions">the Codex</a> for more information.' ); ?> </em></p>
2004-11-17 04:15:44 +01:00
< ? php endif ; ?>
2006-11-19 08:56:05 +01:00
</ form >
< ? php
2004-09-11 18:12:40 +02:00
} else {
echo '<div class="error"><p>' . __ ( 'Oops, no such file exists! Double check the name and try again, merci.' ) . '</p></div>' ;
}
2005-11-14 11:19:22 +01:00
?>
< div class = " clear " > & nbsp ; </ div >
2006-11-19 08:56:05 +01:00
</ div >
2004-09-11 18:12:40 +02:00
< ? php
break ;
}
2006-11-19 08:56:05 +01:00
include ( " admin-footer.php " ) ?>