2004-09-11 12:12:40 -04:00
< ? php
2004-10-18 23:03:06 -04:00
require_once ( 'admin.php' );
2006-11-18 02:31:29 -05:00
$title = __ ( " Edit Themes " );
$parent_file = 'themes.php' ;
2006-07-03 15:03:37 -04:00
wp_reset_vars ( array ( 'action' , 'redirect' , 'profile' , 'error' , 'warning' , 'a' , 'file' , 'theme' ));
2004-09-11 12:12:40 -04:00
2004-11-16 22:15:44 -05:00
$themes = get_themes ();
if ( empty ( $theme )) {
$theme = get_current_theme ();
2005-02-26 01:38:18 -05:00
} else {
$theme = stripslashes ( $theme );
2005-04-19 17:41:35 -04:00
}
if ( ! isset ( $themes [ $theme ]) )
2006-07-05 18:00:03 -04:00
wp_die ( __ ( 'The requested theme does not exist.' ));
2004-11-16 22:15:44 -05:00
2004-11-23 12:51:34 -05:00
$allowed_files = array_merge ( $themes [ $theme ][ 'Stylesheet Files' ], $themes [ $theme ][ 'Template Files' ]);
2004-11-16 22:15:44 -05: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 05:26:39 -05:00
$file_show = basename ( $file );
2004-09-11 12:12:40 -04:00
switch ( $action ) {
case 'update' :
2006-05-26 19:08:05 -04:00
check_admin_referer ( 'edit-theme_' . $file . $theme );
2006-03-30 18:12:54 -05:00
2005-07-14 22:16:45 -04:00
if ( ! current_user_can ( 'edit_themes' ) )
2006-07-05 18:00:03 -04:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit templates for this blog.' ) . '</p>' );
2004-09-11 12:12:40 -04:00
$newcontent = stripslashes ( $_POST [ 'newcontent' ]);
2004-11-25 11:15:27 -05:00
$theme = urlencode ( $theme );
2004-11-16 22:15:44 -05:00
if ( is_writeable ( $real_file )) {
$f = fopen ( $real_file , 'w+' );
fwrite ( $f , $newcontent );
fclose ( $f );
2006-10-02 15:26:12 -04:00
$location = " theme-editor.php?file= $file &theme= $theme &a=te " ;
2004-11-16 22:15:44 -05:00
} else {
2006-10-02 15:26:12 -04:00
$location = " theme-editor.php?file= $file &theme= $theme " ;
2004-11-16 22:15:44 -05:00
}
2004-09-11 12:12:40 -04:00
2006-10-02 15:26:12 -04:00
$location = wp_kses_no_null ( $location );
$strip = array ( '%0d' , '%0a' );
$location = str_replace ( $strip , '' , $location );
header ( " Location: $location " );
2004-09-11 12:12:40 -04:00
exit ();
break ;
default :
2006-02-12 02:53:23 -05:00
2005-07-14 22:16:45 -04:00
if ( ! current_user_can ( 'edit_themes' ) )
2006-07-05 18:00:03 -04:00
wp_die ( '<p>' . __ ( 'You do not have sufficient permissions to edit themes for this blog.' ) . '</p>' );
2004-09-11 12:12:40 -04:00
2006-08-22 14:20:00 -04:00
require_once ( 'admin-header.php' );
2008-02-17 17:17:55 -05:00
wp_admin_css ( 'css/theme-editor' );
2004-11-16 22:15:44 -05:00
update_recently_edited ( $file );
2006-02-12 02:53:23 -05:00
2004-09-11 12:12:40 -04:00
if ( ! is_file ( $real_file ))
$error = 1 ;
2006-02-12 02:53:23 -05:00
2005-03-15 17:25:40 -05:00
if ( ! $error && filesize ( $real_file ) > 0 ) {
2004-09-11 12:12:40 -04:00
$f = fopen ( $real_file , 'r' );
$content = fread ( $f , filesize ( $real_file ));
2005-01-23 18:00:15 -05:00
$content = htmlspecialchars ( $content );
2004-09-11 12:12:40 -04:00
}
?>
< ? php if ( isset ( $_GET [ 'a' ])) : ?>
2005-08-07 21:13:22 -04:00
< div id = " message " class = " updated fade " >< p >< ? php _e ( 'File edited successfully.' ) ?> </p></div>
2008-02-16 17:08:13 -05:00
< ? php endif ;
$description = get_file_description ( $file );
$desc_header = ( $description != $file_show ) ? " $description </strong> (%s) " : " %s " ;
2004-09-11 12:12:40 -04:00
?>
2008-02-16 17:08:13 -05:00
< div class = " wrap " >
< div class = " bordertitle " >
2008-02-16 19:58:23 -05:00
< h2 style = " border: none; padding-bottom: 0px; " >< ? php _e ( 'Theme Editor' ); ?> </h2>
2008-02-16 17:08:13 -05:00
< form id = " themeselector " name = " theme " action = " theme-editor.php " method = " post " >
< strong >< ? php _e ( 'Select theme to edit: ' ); ?> </strong>
< select name = " theme " id = " theme " style = " margin: 0; padding: 0; " >
< ? php
foreach ( $themes as $a_theme ) {
$theme_name = $a_theme [ 'Name' ];
if ( $theme_name == $theme ) $selected = " selected='selected' " ;
else $selected = '' ;
$theme_name = attribute_escape ( $theme_name );
echo " \n \t <option value= \" $theme_name\ " $selected > $theme_name </ option > " ;
}
?>
</ select >
< input type = " submit " name = " Submit " value = " <?php _e('Select') ?> " class = " button " style = " padding: 0px; " />
</ form >
</ div >
< br style = " clear: both; " />
< div class = " tablenav " style = " margin-right: 210px; " >
< div style = " float: left; " >
< big >< strong >< ? php echo sprintf ( $desc_header , $file_show ); ?> </big>
</ div >
< br style = " clear: both; " />
</ div >
< br style = " clear: both; " />
2004-11-16 22:15:44 -05:00
< div id = " templateside " >
2008-02-16 17:08:13 -05:00
< h3 id = " bordertitle " style = " margin-bottom: 10px; " >< ? php _e ( " Theme Files " ); ?> </h3>
2004-11-16 22:15:44 -05:00
< ? php
if ( $allowed_files ) :
?>
2008-02-16 17:08:13 -05:00
< h4 style = " margin-bottom: 0px; " >< ? php _e ( 'Templates' ); ?> </h4>
< ul >
< ? php foreach ( $themes [ $theme ][ 'Template Files' ] as $template_file ) :
$description = get_file_description ( $template_file );
$template_show = basename ( $template_file );
$filedesc = ( $description != $template_file ) ? " $description <span class='nonessential'>( $template_show )</span></small> " : " $description " ;
$filedesc = ( $template_file == $file ) ? " <span class='highlight'> $description <span class='nonessential'>( $template_show )</span></span> " : $filedesc ;
?>
< li >< a href = " theme-editor.php?file=<?php echo " $template_file " ; ?>&theme=<?php echo urlencode( $theme ) ?> " >< ? php echo $filedesc ?> </a></li>
< ? php endforeach ; ?>
</ ul >
< h4 style = " margin-bottom: 0px; " >< ? php _e ( 'Styles' ); ?> </h4>
2006-11-19 02:56:05 -05:00
< ul >
2008-02-16 17:08:13 -05:00
< ? php foreach ( $themes [ $theme ][ 'Stylesheet Files' ] as $style_file ) :
$description = get_file_description ( $style_file );
$style_show = basename ( $style_file );
$filedesc = ( $description != $style_file ) ? " $description <span class='nonessential'>( $style_show )</span> " : " $description " ;
$filedesc = ( $style_file == $file ) ? " <span class='highlight'> $description <span class='nonessential'>( $style_show )</span></span> " : $filedesc ;
?>
< li >< a href = " theme-editor.php?file=<?php echo " $style_file " ; ?>&theme=<?php echo urlencode( $theme ) ?> " >< ? php echo $filedesc ?> </a></li>
2004-11-16 22:15:44 -05:00
< ? php endforeach ; ?>
2006-11-19 02:56:05 -05:00
</ ul >
2004-11-16 22:15:44 -05:00
< ? php endif ; ?>
2006-11-19 02:56:05 -05:00
</ div >
2004-11-16 22:15:44 -05:00
< ? php
2004-09-11 12:12:40 -04:00
if ( ! $error ) {
2006-11-19 02:56:05 -05: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-16 22:15:44 -05:00
</ div >
< ? php if ( is_writeable ( $real_file ) ) : ?>
2006-11-19 02:56:05 -05:00
< p class = " submit " >
2004-11-16 22:15:44 -05:00
< ? php
2006-02-16 20:29:33 -05:00
echo " <input type='submit' name='submit' value=' " . __ ( 'Update File »' ) . " ' tabindex='2' /> " ;
2004-11-16 22:15:44 -05:00
?>
2004-09-11 12:12:40 -04:00
</ p >
2004-11-16 22:15:44 -05:00
< ? php else : ?>
2008-02-09 15:17:49 -05: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-16 22:15:44 -05:00
< ? php endif ; ?>
2006-11-19 02:56:05 -05:00
</ form >
< ? php
2004-09-11 12:12:40 -04: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 05:19:22 -05:00
?>
< div class = " clear " > & nbsp ; </ div >
2006-11-19 02:56:05 -05:00
</ div >
2004-09-11 12:12:40 -04:00
< ? php
break ;
}
2006-11-19 02:56:05 -05:00
include ( " admin-footer.php " ) ?>