X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/f9001779751f83dc8a10e478bfecb4d8dd5f964c..HEAD:/wp-admin/network/themes.php diff --git a/wp-admin/network/themes.php b/wp-admin/network/themes.php index b802f74d..baaa6d80 100644 --- a/wp-admin/network/themes.php +++ b/wp-admin/network/themes.php @@ -8,18 +8,10 @@ */ /** Load WordPress Administration Bootstrap */ -require_once( './admin.php' ); - -if ( ! is_multisite() ) - wp_die( __( 'Multisite support is not enabled.' ) ); - -$menu_perms = get_site_option( 'menu_items', array() ); - -if ( empty( $menu_perms['themes'] ) && ! is_super_admin() ) - wp_die( __( 'Cheatin’ uh?' ) ); +require_once( dirname( __FILE__ ) . '/admin.php' ); if ( !current_user_can('manage_network_themes') ) - wp_die( __( 'You do not have sufficient permissions to manage network themes.' ) ); + wp_die( __( 'Sorry, you are not allowed to manage network themes.' ) ); $wp_list_table = _get_list_table('WP_MS_Themes_List_Table'); $pagenum = $wp_list_table->get_pagenum(); @@ -34,82 +26,91 @@ $_SERVER['REQUEST_URI'] = remove_query_arg( $temp_args, $_SERVER['REQUEST_URI'] $referer = remove_query_arg( $temp_args, wp_get_referer() ); if ( $action ) { - $allowed_themes = get_site_option( 'allowedthemes' ); switch ( $action ) { case 'enable': check_admin_referer('enable-theme_' . $_GET['theme']); - $allowed_themes[ $_GET['theme'] ] = true; - update_site_option( 'allowedthemes', $allowed_themes ); - wp_redirect( add_query_arg( 'enabled', '1', $referer ) ); + WP_Theme::network_enable_theme( $_GET['theme'] ); + if ( false === strpos( $referer, '/network/themes.php' ) ) + wp_redirect( network_admin_url( 'themes.php?enabled=1' ) ); + else + wp_safe_redirect( add_query_arg( 'enabled', 1, $referer ) ); exit; - break; case 'disable': check_admin_referer('disable-theme_' . $_GET['theme']); - unset( $allowed_themes[ $_GET['theme'] ] ); - update_site_option( 'allowedthemes', $allowed_themes ); - wp_redirect( add_query_arg( 'disabled', '1', $referer ) ); + WP_Theme::network_disable_theme( $_GET['theme'] ); + wp_safe_redirect( add_query_arg( 'disabled', '1', $referer ) ); exit; - break; case 'enable-selected': check_admin_referer('bulk-themes'); $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array(); if ( empty($themes) ) { - wp_redirect( add_query_arg( 'error', 'none', $referer ) ); + wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) ); exit; } - foreach( (array) $themes as $theme ) - $allowed_themes[ $theme ] = true; - update_site_option( 'allowedthemes', $allowed_themes ); - wp_redirect( add_query_arg( 'enabled', count( $themes ), $referer ) ); + WP_Theme::network_enable_theme( (array) $themes ); + wp_safe_redirect( add_query_arg( 'enabled', count( $themes ), $referer ) ); exit; - break; case 'disable-selected': check_admin_referer('bulk-themes'); $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array(); if ( empty($themes) ) { - wp_redirect( add_query_arg( 'error', 'none', $referer ) ); + wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) ); exit; } - foreach( (array) $themes as $theme ) - unset( $allowed_themes[ $theme ] ); - update_site_option( 'allowedthemes', $allowed_themes ); - wp_redirect( add_query_arg( 'disabled', count( $themes ), $referer ) ); + WP_Theme::network_disable_theme( (array) $themes ); + wp_safe_redirect( add_query_arg( 'disabled', count( $themes ), $referer ) ); + exit; + 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 '
'; + echo '

' . esc_html( $title ) . '

'; + + $url = self_admin_url('update.php?action=update-selected-themes&themes=' . urlencode( join(',', $themes) )); + $url = wp_nonce_url($url, 'bulk-update-themes'); + + echo ""; + echo '
'; + require_once(ABSPATH . 'wp-admin/admin-footer.php'); exit; - break; case 'delete-selected': - if ( ! current_user_can( 'delete_themes' ) ) - wp_die( __('You do not have sufficient permissions to delete themes for this site.') ); + if ( ! current_user_can( 'delete_themes' ) ) { + wp_die( __('Sorry, you are not allowed to delete themes for this site.') ); + } + check_admin_referer( 'bulk-themes' ); $themes = isset( $_REQUEST['checked'] ) ? (array) $_REQUEST['checked'] : array(); - if ( isset( $themes[ get_option( 'template' ) ] ) ) - unset( $themes[ get_option( 'template' ) ] ); - if ( isset( $themes[ get_option( 'stylesheet' ) ] ) ) - unset( $themes[ get_option( 'stylesheet' ) ] ); - if ( empty( $themes ) ) { - wp_redirect( add_query_arg( 'error', 'none', $referer ) ); + wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) ); exit; } - $main_theme = get_current_theme(); - $files_to_delete = $theme_info = array(); - foreach ( $themes as $key => $theme ) { - $data = get_theme_data( WP_CONTENT_DIR . '/themes/' . $theme . '/style.css' ); - if ( $data['Name'] == $main_theme ) { - unset( $themes[$key] ); - } else { - $files_to_delete = array_merge( $files_to_delete, list_files( WP_CONTENT_DIR . "/themes/$theme" ) ); - $theme_info[ $theme ] = $data; - } - } - + $themes = array_diff( $themes, array( get_option( 'stylesheet' ), get_option( 'template' ) ) ); + if ( empty( $themes ) ) { - wp_redirect( add_query_arg( 'error', 'main', $referer ) ); + wp_safe_redirect( add_query_arg( 'error', 'main', $referer ) ); exit; } + $theme_info = array(); + foreach ( $themes as $key => $theme ) { + $theme_info[ $theme ] = wp_get_theme( $theme ); + } + include(ABSPATH . 'wp-admin/update.php'); $parent_file = 'themes.php'; @@ -117,118 +118,188 @@ if ( $action ) { if ( ! isset( $_REQUEST['verify-delete'] ) ) { wp_enqueue_script( 'jquery' ); require_once( ABSPATH . 'wp-admin/admin-header.php' ); + $themes_to_delete = count( $themes ); ?>
- ' . _n( 'Delete Theme', 'Delete Themes', $themes_to_delete ) . ''; - ?> -

-

+ +

+

+

+ +

+

+

+ -

+ +

+ +

+
'; + } + + wp_nonce_field( 'bulk-themes' ); + + if ( 1 == $themes_to_delete ) { + submit_button( __( 'Yes, delete this theme' ), '', 'submit', false ); + } else { + submit_button( __( 'Yes, delete these themes' ), '', 'submit', false ); + } ?> - -
-
- + + +
- -

-
1), $_SERVER['REQUEST_URI'] ) ) ); - $paged = ( $_REQUEST['paged'] ) ? $_REQUEST['paged'] : 1; - wp_redirect( network_admin_url( "themes.php?deleted=".count( $themes )."&paged=$paged&s=$s" ) ); + foreach ( $themes as $theme ) { + $delete_result = delete_theme( $theme, esc_url( add_query_arg( array( + 'verify-delete' => 1, + 'action' => 'delete-selected', + 'checked' => $_REQUEST['checked'], + '_wpnonce' => $_REQUEST['_wpnonce'] + ), network_admin_url( 'themes.php' ) ) ) ); + } + + $paged = ( $_REQUEST['paged'] ) ? $_REQUEST['paged'] : 1; + wp_redirect( add_query_arg( array( + 'deleted' => count( $themes ), + 'paged' => $paged, + 's' => $s + ), network_admin_url( 'themes.php' ) ) ); + exit; + default: + $themes = isset( $_POST['checked'] ) ? (array) $_POST['checked'] : array(); + if ( empty( $themes ) ) { + wp_safe_redirect( add_query_arg( 'error', 'none', $referer ) ); + exit; + } + check_admin_referer( 'bulk-themes' ); + + /** This action is documented in wp-admin/network/site-themes.php */ + $referer = apply_filters( 'handle_network_bulk_actions-' . get_current_screen()->id, $referer, $action, $themes ); + + wp_safe_redirect( $referer ); exit; - break; } + } $wp_list_table->prepare_items(); -$total_pages = $wp_list_table->get_pagination_arg( 'total_pages' ); -if ( $pagenum > $total_pages && $total_pages > 0 ) { - wp_redirect( add_query_arg( 'paged', $total_pages ) ); - exit; -} - add_thickbox(); -add_screen_option( 'per_page', array('label' => _x( 'Themes', 'themes per page (screen options)' )) ); +add_screen_option( 'per_page' ); -add_contextual_help($current_screen, - '

' . __('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.') . '

' . - '

' . __('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.') . '

' . - '

' . __('Themes can be enabled on a site by site basis by the network admin on the Edit Site screen you go to via the Edit action link on the Sites screen. Only network admins are able to install or edit themes.') . '

' . +get_current_screen()->add_help_tab( array( + 'id' => 'overview', + 'title' => __('Overview'), + 'content' => + '

' . __('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.') . '

' . + '

' . __('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.') . '

' . + '

' . __('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.') . '

' +) ); + +get_current_screen()->set_help_sidebar( '

' . __('For more information:') . '

' . - '

' . __('Documentation on Network Themes') . '

' . - '

' . __('Support Forums') . '

' + '

' . __('Documentation on Network Themes') . '

' . + '

' . __('Support Forums') . '

' ); +get_current_screen()->set_screen_reader_content( array( + 'heading_views' => __( 'Filter themes list' ), + 'heading_pagination' => __( 'Themes list navigation' ), + 'heading_list' => __( 'Themes list' ), +) ); + $title = __('Themes'); $parent_file = 'themes.php'; +wp_enqueue_script( 'updates' ); +wp_enqueue_script( 'theme-preview' ); + require_once(ABSPATH . 'wp-admin/admin-header.php'); ?>
- -

' . __('Search results for “%s”') . '', esc_html( $s ) ); ?> -

+

' . __( 'Search results for “%s”' ) . '', esc_html( $s ) ); +} +?> +

' . sprintf( _n( 'Theme enabled.', '%s themes enabled.', $_GET['enabled'] ), number_format_i18n( $_GET['enabled'] ) ) . '

'; + $enabled = absint( $_GET['enabled'] ); + if ( 1 == $enabled ) { + $message = __( 'Theme enabled.' ); + } else { + $message = _n( '%s theme enabled.', '%s themes enabled.', $enabled ); + } + echo '

' . sprintf( $message, number_format_i18n( $enabled ) ) . '

'; } elseif ( isset( $_GET['disabled'] ) ) { - $_GET['disabled'] = absint( $_GET['disabled'] ); - echo '

' . sprintf( _n( 'Theme disabled.', '%s themes disabled.', $_GET['disabled'] ), number_format_i18n( $_GET['disabled'] ) ) . '

'; + $disabled = absint( $_GET['disabled'] ); + if ( 1 == $disabled ) { + $message = __( 'Theme disabled.' ); + } else { + $message = _n( '%s theme disabled.', '%s themes disabled.', $disabled ); + } + echo '

' . sprintf( $message, number_format_i18n( $disabled ) ) . '

'; } elseif ( isset( $_GET['deleted'] ) ) { - $_GET['deleted'] = absint( $_GET['deleted'] ); - echo '

' . sprintf( _nx( 'Theme deleted.', '%s themes deleted.', $_GET['deleted'], 'network' ), number_format_i18n( $_GET['deleted'] ) ) . '

'; + $deleted = absint( $_GET['deleted'] ); + if ( 1 == $deleted ) { + $message = __( 'Theme deleted.' ); + } else { + $message = _n( '%s theme deleted.', '%s themes deleted.', $deleted ); + } + echo '

' . sprintf( $message, number_format_i18n( $deleted ) ) . '

'; } elseif ( isset( $_GET['error'] ) && 'none' == $_GET['error'] ) { - echo '

' . __( 'No theme selected.' ) . '

'; + echo '

' . __( 'No theme selected.' ) . '

'; } elseif ( isset( $_GET['error'] ) && 'main' == $_GET['error'] ) { - echo '

' . __( 'You cannot delete a theme while it is active on the main site.' ) . '

'; + echo '

' . __( 'You cannot delete a theme while it is active on the main site.' ) . '

'; } ?> -
+ search_box( __( 'Search Installed Themes' ), 'theme' ); ?>
-views(); ?> +views(); -
+if ( 'broken' == $status ) + echo '

' . __( 'The following themes are installed but incomplete.' ) . '

'; +?> + + @@ -238,4 +309,8 @@ if ( isset( $_GET['enabled'] ) ) {