2004-09-11 18:12:40 +02:00
< ? php
2008-08-16 09:27:34 +02:00
/**
* Theme editor administration panel .
*
* @ package WordPress
* @ subpackage Administration
*/
/** WordPress Administration Bootstrap */
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
2008-05-22 02:06:41 +02:00
wp_admin_css ( 'theme-editor' );
2008-02-18 00:53:36 +01: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 )) {
2008-06-27 22:14:50 +02:00
//is_writable() not always reliable, check return value. see comments @ http://uk.php.net/is_writable
2004-11-17 04:15:44 +01:00
$f = fopen ( $real_file , 'w+' );
2008-06-27 22:14:50 +02:00
if ( $f !== FALSE ) {
fwrite ( $f , $newcontent );
fclose ( $f );
$location = " theme-editor.php?file= $file &theme= $theme &a=te " ;
} else {
$location = " theme-editor.php?file= $file &theme= $theme " ;
}
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
2009-06-07 03:52:44 +02:00
if ( use_codepress () )
wp_enqueue_script ( 'codepress' );
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
2009-03-06 17:17:57 +01:00
if ( ! is_file ( $real_file ) )
2004-09-11 18:12:40 +02:00
$error = 1 ;
2006-02-12 08:53:23 +01:00
2009-03-06 17:17:57 +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 ));
2009-02-20 21:00:09 +01:00
2009-03-06 17:17:57 +01:00
if ( '.php' == substr ( $real_file , strrpos ( $real_file , '.' ) ) ) {
2009-02-20 21:00:09 +01:00
$functions = wp_doc_link_parse ( $content );
2009-03-06 17:17:57 +01:00
2009-02-20 21:00:09 +01:00
$docs_select = '<select name="docs-list" id="docs-list">' ;
2009-05-05 21:43:53 +02:00
$docs_select .= '<option value="">' . esc_attr__ ( 'Function Name...' ) . '</option>' ;
2009-03-06 17:17:57 +01:00
foreach ( $functions as $function ) {
2009-05-05 21:43:53 +02:00
$docs_select .= '<option value="' . esc_attr ( urlencode ( $function ) ) . '">' . htmlspecialchars ( $function ) . '()</option>' ;
2009-02-20 21:00:09 +01:00
}
$docs_select .= '</select>' ;
}
$content = htmlspecialchars ( $content );
2009-02-21 03:12:00 +01:00
$codepress_lang = codepress_get_lang ( $real_file );
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>
2008-03-02 21:17:30 +01:00
< ? php endif ;
2008-02-16 23:08:13 +01:00
$description = get_file_description ( $file );
2008-12-12 09:19:10 +01:00
$desc_header = ( $description != $file_show ) ? " <strong> $description </strong> (%s) " : " %s " ;
2004-09-11 18:12:40 +02:00
?>
2008-02-16 23:08:13 +01:00
< div class = " wrap " >
2008-11-26 14:51:25 +01:00
< ? php screen_icon (); ?>
2009-05-18 17:11:07 +02:00
< h2 >< ? php echo esc_html ( $title ); ?> </h2>
2008-02-16 23:08:13 +01:00
< div class = " bordertitle " >
2008-09-08 08:01:33 +02:00
< form id = " themeselector " action = " theme-editor.php " method = " post " >
2008-05-04 12:37:06 +02:00
< strong >< label for = " theme " >< ? php _e ( 'Select theme to edit:' ); ?> </label></strong>
2008-03-15 00:58:31 +01:00
< select name = " theme " id = " theme " >
2008-02-16 23:08:13 +01:00
< ? php
foreach ( $themes as $a_theme ) {
$theme_name = $a_theme [ 'Name' ];
if ( $theme_name == $theme ) $selected = " selected='selected' " ;
else $selected = '' ;
2009-05-05 21:43:53 +02:00
$theme_name = esc_attr ( $theme_name );
2008-02-16 23:08:13 +01:00
echo " \n \t <option value= \" $theme_name\ " $selected > $theme_name </ option > " ;
}
?>
</ select >
2009-05-05 21:43:53 +02:00
< input type = " submit " name = " Submit " value = " <?php esc_attr_e('Select') ?> " class = " button " />
2008-02-16 23:08:13 +01:00
</ form >
</ div >
2008-03-15 00:58:31 +01:00
< div class = " tablenav " >
< div class = " alignleft " >
2008-12-12 09:19:10 +01:00
< big >< ? php echo sprintf ( $desc_header , $file_show ); ?> </big>
2008-02-16 23:08:13 +01:00
</ div >
2008-03-15 00:58:31 +01:00
< br class = " clear " />
2008-02-16 23:08:13 +01:00
</ div >
2008-03-15 00:58:31 +01:00
< br class = " clear " />
2004-11-17 04:15:44 +01:00
< div id = " templateside " >
2008-03-15 00:58:31 +01:00
< h3 id = " bordertitle " >< ? php _e ( " Theme Files " ); ?> </h3>
2004-11-17 04:15:44 +01:00
< ? php
if ( $allowed_files ) :
?>
2008-03-15 00:58:31 +01:00
< h4 >< ? php _e ( 'Templates' ); ?> </h4>
2008-02-16 23:08:13 +01:00
< ul >
2008-08-23 11:28:39 +02:00
< ? php
$template_mapping = array ();
2008-12-04 22:29:55 +01:00
$template_dir = $themes [ $theme ][ 'Template Dir' ];
2009-03-25 17:51:08 +01:00
foreach ( $themes [ $theme ][ 'Template Files' ] as $template_file ) {
2008-08-23 11:28:39 +02:00
$description = trim ( get_file_description ( $template_file ) );
2008-02-16 23:08:13 +01:00
$template_show = basename ( $template_file );
2008-02-21 22:49:48 +01:00
$filedesc = ( $description != $template_file ) ? " $description <span class='nonessential'>( $template_show )</span> " : " $description " ;
2008-02-16 23:08:13 +01:00
$filedesc = ( $template_file == $file ) ? " <span class='highlight'> $description <span class='nonessential'>( $template_show )</span></span> " : $filedesc ;
2008-12-09 19:03:31 +01:00
2008-12-04 22:29:55 +01:00
// If we have two files of the same name prefer the one in the Template Directory
// This means that we display the correct files for child themes which overload Templates as well as Styles
if ( array_key_exists ( $description , $template_mapping ) ) {
2008-12-09 19:03:31 +01:00
if ( false !== strpos ( $template_file , $template_dir ) ) {
2008-12-04 22:29:55 +01:00
$template_mapping [ $description ] = array ( $template_file , $filedesc );
}
} else {
$template_mapping [ $description ] = array ( $template_file , $filedesc );
}
2008-08-23 11:28:39 +02:00
}
ksort ( $template_mapping );
while ( list ( $template_sorted_key , list ( $template_file , $filedesc ) ) = each ( $template_mapping ) ) :
?>
2008-02-16 23:08:13 +01:00
< li >< a href = " theme-editor.php?file=<?php echo " $template_file " ; ?>&theme=<?php echo urlencode( $theme ) ?> " >< ? php echo $filedesc ?> </a></li>
2008-08-23 11:28:39 +02:00
< ? php endwhile ; ?>
2008-02-16 23:08:13 +01:00
</ ul >
2009-03-11 00:02:29 +01:00
< h4 >< ? php /* translators: Theme stylesheets in theme editor */ echo _x ( 'Styles' , 'Theme stylesheets in theme editor' ); ?> </h4>
2006-11-19 08:56:05 +01:00
< ul >
2008-08-23 11:28:39 +02:00
< ? php
$template_mapping = array ();
2009-03-25 17:51:08 +01:00
foreach ( $themes [ $theme ][ 'Stylesheet Files' ] as $style_file ) {
2008-08-23 11:28:39 +02:00
$description = trim ( get_file_description ( $style_file ) );
2008-02-16 23:08:13 +01:00
$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 ;
2008-08-23 11:28:39 +02:00
$template_mapping [ $description ] = array ( $style_file , $filedesc );
}
ksort ( $template_mapping );
while ( list ( $template_sorted_key , list ( $style_file , $filedesc ) ) = each ( $template_mapping ) ) :
2008-02-16 23:08:13 +01:00
?>
< li >< a href = " theme-editor.php?file=<?php echo " $style_file " ; ?>&theme=<?php echo urlencode( $theme ) ?> " >< ? php echo $filedesc ?> </a></li>
2008-08-23 11:28:39 +02:00
< ? php endwhile ; ?>
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 ) ?>
2009-02-21 03:12:00 +01:00
< div >< textarea cols = " 70 " rows = " 25 " name = " newcontent " id = " newcontent " tabindex = " 1 " class = " codepress <?php echo $codepress_lang ?> " >< ? php echo $content ?> </textarea>
2006-11-19 08:56:05 +01:00
< input type = " hidden " name = " action " value = " update " />
2009-05-05 21:43:53 +02:00
< input type = " hidden " name = " file " value = " <?php echo esc_attr( $file ) ?> " />
< input type = " hidden " name = " theme " value = " <?php echo esc_attr( $theme ) ?> " />
2004-11-17 04:15:44 +01:00
</ div >
2009-03-15 18:14:44 +01:00
< ? php if ( isset ( $functions ) && count ( $functions ) ) { ?>
< div id = " documentation " >
2009-03-25 17:51:08 +01:00
< label for = " docs-list " >< ? php _e ( 'Documentation:' ) ?> </label>
2009-03-15 18:14:44 +01:00
< ? php echo $docs_select ; ?>
2009-05-05 21:43:53 +02:00
< input type = " button " class = " button " value = " <?php esc_attr_e( 'Lookup' ); ?> " onclick = " if ( '' != jQuery('#docs-list').val() ) { window.open( 'http://api.wordpress.org/core/handbook/1.0/?function=' + escape( jQuery( '#docs-list' ).val() ) + '&locale=<?php echo urlencode( get_locale() ) ?>&version=<?php echo urlencode( $wp_version ) ?>&redirect=true'); } " />
2009-03-15 18:14:44 +01:00
</ div >
< ? php } ?>
2008-03-02 21:17:30 +01:00
2008-02-17 23:23:04 +01:00
< div >
2004-11-17 04:15:44 +01:00
< ? php if ( is_writeable ( $real_file ) ) : ?>
2008-02-17 23:23:04 +01:00
< p class = " submit " >
2004-11-17 04:15:44 +01:00
< ? php
2009-05-05 21:43:53 +02:00
echo " <input type='submit' name='submit' class='button-primary' value=' " . esc_attr__ ( '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 ; ?>
2008-02-17 23:23:04 +01:00
</ div >
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 " ) ?>