2010-07-30 22:34:54 +02:00
< ? php
/**
* Multisite themes administration panel .
*
* @ package WordPress
* @ subpackage Multisite
2010-10-31 10:37:15 +01:00
* @ since 3.1 . 0
2010-07-30 22:34:54 +02:00
*/
2010-11-10 15:27:15 +01:00
/** Load WordPress Administration Bootstrap */
2010-07-30 22:34:54 +02:00
require_once ( './admin.php' );
2010-11-10 15:27:15 +01:00
if ( ! is_multisite () )
wp_die ( __ ( 'Multisite support is not enabled.' ) );
2010-12-15 20:24:42 +01:00
$menu_perms = get_site_option ( 'menu_items' , array () );
2010-12-16 09:43:22 +01:00
if ( empty ( $menu_perms [ 'themes' ] ) && ! is_super_admin () )
wp_die ( __ ( 'Cheatin’ uh?' ) );
2010-12-15 20:24:42 +01:00
if ( ! current_user_can ( 'manage_network_themes' ) )
wp_die ( __ ( 'You do not have sufficient permissions to manage network themes.' ) );
2011-01-16 22:47:24 +01:00
$wp_list_table = _get_list_table ( 'WP_MS_Themes_List_Table' );
2011-01-13 01:03:38 +01:00
$pagenum = $wp_list_table -> get_pagenum ();
2010-07-30 22:34:54 +02:00
2010-10-31 10:37:15 +01:00
$action = $wp_list_table -> current_action ();
$s = isset ( $_REQUEST [ 's' ]) ? $_REQUEST [ 's' ] : '' ;
// Clean up request URI from temporary args for screen options/paging uri's to work as expected.
2010-12-25 14:44:03 +01:00
$temp_args = array ( 'enabled' , 'disabled' , 'deleted' , 'error' );
2010-12-24 18:41:36 +01:00
$_SERVER [ 'REQUEST_URI' ] = remove_query_arg ( $temp_args , $_SERVER [ 'REQUEST_URI' ] );
$referer = remove_query_arg ( $temp_args , wp_get_referer () );
2010-10-31 10:37:15 +01:00
if ( $action ) {
2011-05-10 21:18:16 +02:00
$allowed_themes = get_site_option ( 'allowedthemes' );
2010-10-31 10:37:15 +01:00
switch ( $action ) {
2010-11-08 22:52:54 +01:00
case 'enable' :
2010-12-23 17:20:36 +01:00
check_admin_referer ( 'enable-theme_' . $_GET [ 'theme' ]);
2010-11-08 20:40:05 +01:00
$allowed_themes [ $_GET [ 'theme' ] ] = true ;
2010-10-31 10:37:15 +01:00
update_site_option ( 'allowedthemes' , $allowed_themes );
2011-08-19 00:40:37 +02:00
wp_redirect ( network_admin_url ( 'themes.php?enabled=1' ) );
2010-12-24 18:41:36 +01:00
exit ;
2010-10-31 10:37:15 +01:00
break ;
2010-11-08 22:52:54 +01:00
case 'disable' :
2010-12-23 17:20:36 +01:00
check_admin_referer ( 'disable-theme_' . $_GET [ 'theme' ]);
2010-10-31 10:37:15 +01:00
unset ( $allowed_themes [ $_GET [ 'theme' ] ] );
update_site_option ( 'allowedthemes' , $allowed_themes );
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'disabled' , '1' , $referer ) );
2010-10-31 10:37:15 +01:00
exit ;
break ;
2010-11-08 22:52:54 +01:00
case 'enable-selected' :
2010-12-23 17:20:36 +01:00
check_admin_referer ( 'bulk-themes' );
2010-10-31 10:37:15 +01:00
$themes = isset ( $_POST [ 'checked' ] ) ? ( array ) $_POST [ 'checked' ] : array ();
if ( empty ( $themes ) ) {
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'error' , 'none' , $referer ) );
2010-10-31 10:37:15 +01:00
exit ;
2010-12-24 18:41:36 +01:00
}
2010-10-31 10:37:15 +01:00
foreach ( ( array ) $themes as $theme )
2010-11-08 20:40:05 +01:00
$allowed_themes [ $theme ] = true ;
2010-10-31 10:37:15 +01:00
update_site_option ( 'allowedthemes' , $allowed_themes );
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'enabled' , count ( $themes ), $referer ) );
exit ;
2010-10-31 10:37:15 +01:00
break ;
2010-11-08 22:52:54 +01:00
case 'disable-selected' :
2010-12-23 17:20:36 +01:00
check_admin_referer ( 'bulk-themes' );
2010-11-04 21:11:08 +01:00
$themes = isset ( $_POST [ 'checked' ] ) ? ( array ) $_POST [ 'checked' ] : array ();
if ( empty ( $themes ) ) {
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'error' , 'none' , $referer ) );
2010-11-04 21:11:08 +01:00
exit ;
2010-12-24 18:41:36 +01:00
}
2010-11-04 21:11:08 +01:00
foreach ( ( array ) $themes as $theme )
unset ( $allowed_themes [ $theme ] );
update_site_option ( 'allowedthemes' , $allowed_themes );
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'disabled' , count ( $themes ), $referer ) );
exit ;
2010-11-04 21:11:08 +01:00
break ;
2011-10-03 16:35:43 +02:00
case 'update-selected' :
check_admin_referer ( 'bulk-themes' );
if ( isset ( $_GET [ 'themes' ] ) )
$themes = explode ( ',' , $_GET [ 'themes' ] );
elseif ( isset ( $_POST [ 'checked' ] ) )
$themes = ( array ) $_POST [ 'checked' ];
else
$themes = array ();
$title = __ ( 'Update Themes' );
$parent_file = 'themes.php' ;
require_once ( ABSPATH . 'wp-admin/admin-header.php' );
echo '<div class="wrap">' ;
screen_icon ();
echo '<h2>' . esc_html ( $title ) . '</h2>' ;
$url = self_admin_url ( 'update.php?action=update-selected-themes&themes=' . urlencode ( join ( ',' , $themes ) ));
$url = wp_nonce_url ( $url , 'bulk-update-themes' );
echo " <iframe src=' $url ' style='width: 100%; height:100%; min-height:850px;'></iframe> " ;
echo '</div>' ;
require_once ( ABSPATH . 'wp-admin/admin-footer.php' );
exit ;
break ;
2010-12-21 17:50:16 +01:00
case 'delete-selected' :
if ( ! current_user_can ( 'delete_themes' ) )
wp_die ( __ ( 'You do not have sufficient permissions to delete themes for this site.' ) );
2010-12-23 19:53:44 +01:00
check_admin_referer ( 'bulk-themes' );
2010-12-21 17:50:16 +01:00
$themes = isset ( $_REQUEST [ 'checked' ] ) ? ( array ) $_REQUEST [ 'checked' ] : array ();
2010-12-24 18:41:36 +01:00
if ( isset ( $themes [ get_option ( 'template' ) ] ) )
unset ( $themes [ get_option ( 'template' ) ] );
if ( isset ( $themes [ get_option ( 'stylesheet' ) ] ) )
unset ( $themes [ get_option ( 'stylesheet' ) ] );
2010-12-21 17:50:16 +01:00
if ( empty ( $themes ) ) {
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'error' , 'none' , $referer ) );
2010-12-21 17:50:16 +01:00
exit ;
}
$main_theme = get_current_theme ();
$files_to_delete = $theme_info = array ();
2010-12-23 16:56:32 +01:00
foreach ( $themes as $key => $theme ) {
2010-12-21 17:50:16 +01:00
$data = get_theme_data ( WP_CONTENT_DIR . '/themes/' . $theme . '/style.css' );
if ( $data [ 'Name' ] == $main_theme ) {
unset ( $themes [ $key ] );
} else {
2011-05-10 21:18:16 +02:00
$files_to_delete = array_merge ( $files_to_delete , list_files ( WP_CONTENT_DIR . " /themes/ $theme " ) );
2010-12-21 17:50:16 +01:00
$theme_info [ $theme ] = $data ;
}
}
2011-05-10 21:18:16 +02:00
2010-12-21 17:50:16 +01:00
if ( empty ( $themes ) ) {
2010-12-24 18:41:36 +01:00
wp_redirect ( add_query_arg ( 'error' , 'main' , $referer ) );
2010-12-21 17:50:16 +01:00
exit ;
}
2010-12-23 16:56:32 +01:00
2010-12-21 17:50:16 +01:00
include ( ABSPATH . 'wp-admin/update.php' );
$parent_file = 'themes.php' ;
if ( ! isset ( $_REQUEST [ 'verify-delete' ] ) ) {
wp_enqueue_script ( 'jquery' );
require_once ( ABSPATH . 'wp-admin/admin-header.php' );
?>
< div class = " wrap " >
< ? php
$themes_to_delete = count ( $themes );
screen_icon ();
echo '<h2>' . _n ( 'Delete Theme' , 'Delete Themes' , $themes_to_delete ) . '</h2>' ;
?>
< div class = " error " >< p >< strong >< ? php _e ( 'Caution:' ); ?> </strong> <?php echo _n( 'This theme may be active on other sites in the network.', 'These themes may be active on other sites in the network.', $themes_to_delete ); ?></p></div>
< p >< ? php echo _n ( 'You are about to remove the following theme:' , 'You are about to remove the following themes:' , $themes_to_delete ); ?> </p>
< ul class = " ul-disc " >
< ? php foreach ( $theme_info as $theme )
echo '<li>' , sprintf ( __ ( '<strong>%1$s</strong> by <em>%2$s</em>' ), esc_html ( $theme [ 'Name' ] ), esc_html ( $theme [ 'AuthorName' ] ) ), '</li>' ; /* translators: 1: theme name, 2: theme author */ ?>
</ ul >
< p >< ? php _e ( 'Are you sure you wish to delete these themes?' ); ?> </p>
< form method = " post " action = " <?php echo esc_url( $_SERVER['REQUEST_URI'] ); ?> " style = " display:inline; " >
< input type = " hidden " name = " verify-delete " value = " 1 " />
< input type = " hidden " name = " action " value = " delete-selected " />
< ? php
foreach ( ( array ) $themes as $theme )
echo '<input type="hidden" name="checked[]" value="' . esc_attr ( $theme ) . '" />' ;
?>
< ? php wp_nonce_field ( 'bulk-themes' ) ?>
< ? php submit_button ( _n ( 'Yes, Delete this theme' , 'Yes, Delete these themes' , $themes_to_delete ), 'button' , 'submit' , false ); ?>
</ form >
< form method = " post " action = " <?php echo esc_url(wp_get_referer()); ?> " style = " display:inline; " >
< ? php submit_button ( __ ( 'No, Return me to the theme list' ), 'button' , 'submit' , false ); ?>
</ form >
< p >< a href = " # " onclick = " jQuery('#files-list').toggle(); return false; " >< ? php _e ( 'Click to view entire list of files which will be deleted' ); ?> </a></p>
< div id = " files-list " style = " display:none; " >
< ul class = " code " >
< ? php
foreach ( ( array ) $files_to_delete as $file )
echo '<li>' . esc_html ( str_replace ( WP_CONTENT_DIR . " /themes " , '' , $file ) ) . '</li>' ;
?>
</ ul >
</ div >
</ div >
< ? php
require_once ( ABSPATH . 'wp-admin/admin-footer.php' );
exit ;
2010-12-23 16:56:32 +01:00
} // Endif verify-delete
2010-12-23 20:40:32 +01:00
2010-12-23 16:56:32 +01:00
foreach ( $themes as $theme )
2011-01-07 20:01:34 +01:00
$delete_result = delete_theme ( $theme , esc_url ( add_query_arg ( array ( 'verify-delete' => 1 ), $_SERVER [ 'REQUEST_URI' ] ) ) );
2011-05-10 21:18:16 +02:00
$paged = ( $_REQUEST [ 'paged' ] ) ? $_REQUEST [ 'paged' ] : 1 ;
2011-01-07 20:58:25 +01:00
wp_redirect ( network_admin_url ( " themes.php?deleted= " . count ( $themes ) . " &paged= $paged &s= $s " ) );
2010-12-21 17:50:16 +01:00
exit ;
break ;
2010-10-31 10:37:15 +01:00
}
2010-07-30 22:34:54 +02:00
}
2010-10-31 10:37:15 +01:00
$wp_list_table -> prepare_items ();
2011-01-13 01:03:38 +01:00
2010-11-01 21:08:25 +01:00
add_thickbox ();
2010-10-31 10:37:15 +01:00
2011-10-07 06:57:12 +02:00
add_screen_option ( 'per_page' , array ( 'label' => _x ( 'Themes' , 'themes per page (screen options)' )) );
2011-10-02 08:59:36 +02:00
2010-12-18 19:27:12 +01:00
add_contextual_help ( $current_screen ,
'<p>' . __ ( 'This screen enables and disables the inclusion of themes available to choose in the Appearance menu for each site. It does not activate or deactivate which theme a site is currently using.' ) . '</p>' .
'<p>' . __ ( 'If the network admin disables a theme that is in use, it can still remain selected on that site. If another theme is chosen, the disabled theme will not appear in the site’s Appearance > Themes screen.' ) . '</p>' .
2011-11-02 06:33:53 +01:00
'<p>' . __ ( 'Themes can be enabled on a site by site basis by the network admin on the Edit Site screen (which has a Themes tab); get there via the Edit action link on the All Sites screen. Only network admins are able to install or edit themes.' ) . '</p>'
);
2011-11-02 22:32:16 +01:00
get_current_screen () -> set_help_sidebar (
2010-12-18 19:27:12 +01:00
'<p><strong>' . __ ( 'For more information:' ) . '</strong></p>' .
'<p>' . __ ( '<a href="http://codex.wordpress.org/Network_Admin_Themes_Screen" target="_blank">Documentation on Network Themes</a>' ) . '</p>' .
'<p>' . __ ( '<a href="http://wordpress.org/support/" target="_blank">Support Forums</a>' ) . '</p>'
2010-11-01 00:23:32 +01:00
);
2010-10-31 10:37:15 +01:00
$title = __ ( 'Themes' );
$parent_file = 'themes.php' ;
require_once ( ABSPATH . 'wp-admin/admin-header.php' );
2010-07-30 22:34:54 +02:00
?>
2010-10-31 10:37:15 +01:00
2010-07-30 22:34:54 +02:00
< div class = " wrap " >
2010-10-31 10:37:15 +01:00
< ? php screen_icon ( 'themes' ); ?>
2011-05-12 02:22:22 +02:00
< h2 >< ? php echo esc_html ( $title ); if ( current_user_can ( 'install_themes' ) ) { ?> <a href="theme-install.php" class="add-new-h2"><?php echo esc_html_x('Add New', 'theme'); ?></a><?php }
2011-05-10 21:18:16 +02:00
if ( $s )
printf ( '<span class="subtitle">' . __ ( 'Search results for “%s”' ) . '</span>' , esc_html ( $s ) ); ?>
2010-12-19 02:11:38 +01:00
</ h2 >
2010-10-31 10:37:15 +01:00
2010-12-24 18:41:36 +01:00
< ? php
if ( isset ( $_GET [ 'enabled' ] ) ) {
$_GET [ 'enabled' ] = absint ( $_GET [ 'enabled' ] );
echo '<div id="message" class="updated"><p>' . sprintf ( _n ( 'Theme enabled.' , '%s themes enabled.' , $_GET [ 'enabled' ] ), number_format_i18n ( $_GET [ 'enabled' ] ) ) . '</p></div>' ;
} elseif ( isset ( $_GET [ 'disabled' ] ) ) {
$_GET [ 'disabled' ] = absint ( $_GET [ 'disabled' ] );
echo '<div id="message" class="updated"><p>' . sprintf ( _n ( 'Theme disabled.' , '%s themes disabled.' , $_GET [ 'disabled' ] ), number_format_i18n ( $_GET [ 'disabled' ] ) ) . '</p></div>' ;
} elseif ( isset ( $_GET [ 'deleted' ] ) ) {
2011-01-06 09:51:45 +01:00
$_GET [ 'deleted' ] = absint ( $_GET [ 'deleted' ] );
2011-01-07 17:23:52 +01:00
echo '<div id="message" class="updated"><p>' . sprintf ( _nx ( 'Theme deleted.' , '%s themes deleted.' , $_GET [ 'deleted' ], 'network' ), number_format_i18n ( $_GET [ 'deleted' ] ) ) . '</p></div>' ;
2010-12-24 18:41:36 +01:00
} elseif ( isset ( $_GET [ 'error' ] ) && 'none' == $_GET [ 'error' ] ) {
echo '<div id="message" class="error"><p>' . __ ( 'No theme selected.' ) . '</p></div>' ;
} elseif ( isset ( $_GET [ 'error' ] ) && 'main' == $_GET [ 'error' ] ) {
echo '<div class="error"><p>' . __ ( 'You cannot delete a theme while it is active on the main site.' ) . '</p></div>' ;
}
?>
2010-10-31 10:37:15 +01:00
< form method = " get " action = " " >
2010-12-16 21:45:10 +01:00
< ? php $wp_list_table -> search_box ( __ ( 'Search Installed Themes' ), 'theme' ); ?>
2010-10-31 10:37:15 +01:00
</ form >
< ? php $wp_list_table -> views (); ?>
< form method = " post " action = " " >
< input type = " hidden " name = " theme_status " value = " <?php echo esc_attr( $status ) ?> " />
< input type = " hidden " name = " paged " value = " <?php echo esc_attr( $page ) ?> " />
< ? php $wp_list_table -> display (); ?>
</ form >
2010-07-30 22:34:54 +02:00
</ div >
2010-10-31 10:37:15 +01:00
< ? php
2010-12-16 21:45:10 +01:00
include ( ABSPATH . 'wp-admin/admin-footer.php' );