X-Git-Url: https://scripts.mit.edu/gitweb/autoinstalls/wordpress.git/blobdiff_plain/41578db67d72562346e4dbb2a14889b23d522813..refs/tags/wordpress-4.3:/wp-admin/includes/class-wp-theme-install-list-table.php?ds=sidebyside diff --git a/wp-admin/includes/class-wp-theme-install-list-table.php b/wp-admin/includes/class-wp-theme-install-list-table.php index e991c4ec..427c5391 100644 --- a/wp-admin/includes/class-wp-theme-install-list-table.php +++ b/wp-admin/includes/class-wp-theme-install-list-table.php @@ -9,13 +9,25 @@ */ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { - var $features = array(); + public $features = array(); - function ajax_user_can() { + /** + * + * @return bool + */ + public function ajax_user_can() { return current_user_can( 'install_themes' ); } - function prepare_items() { + /** + * + * @global array $tabs + * @global string $tab + * @global int $paged + * @global string $type + * @global array $theme_field_defaults + */ + public function prepare_items() { include( ABSPATH . 'wp-admin/includes/theme-install.php' ); global $tabs, $tab, $paged, $type, $theme_field_defaults; @@ -41,21 +53,14 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { if ( 'search' == $tab ) $tabs['search'] = __( 'Search Results' ); $tabs['upload'] = __( 'Upload' ); - $tabs['featured'] = _x( 'Featured','Theme Installer' ); - //$tabs['popular'] = _x( 'Popular','Theme Installer' ); - $tabs['new'] = _x( 'Newest','Theme Installer' ); - $tabs['updated'] = _x( 'Recently Updated','Theme Installer' ); + $tabs['featured'] = _x( 'Featured', 'themes' ); + //$tabs['popular'] = _x( 'Popular', 'themes' ); + $tabs['new'] = _x( 'Latest', 'themes' ); + $tabs['updated'] = _x( 'Recently Updated', 'themes' ); $nonmenu_tabs = array( 'theme-information' ); // Valid actions to perform which do not have a Menu item. - /** - * Filter the tabs shown on the Install Themes screen. - * - * @since 2.8.0 - * - * @param array $tabs The tabs shown on the Install Themes screen. Defaults are - * 'dashboard', 'search', 'upload', 'featured', 'new', and 'updated'. - */ + /** This filter is documented in wp-admin/theme-install.php */ $tabs = apply_filters( 'install_themes_tabs', $tabs ); /** @@ -99,7 +104,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { break; case 'featured': - //case 'popular': + // case 'popular': case 'new': case 'updated': $args['browse'] = $tab; @@ -113,7 +118,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { /** * Filter API request arguments for each Install Themes screen tab. * - * The dynamic portion of the hook name, $tab, refers to the theme install + * The dynamic portion of the hook name, `$tab`, refers to the theme install * tabs. Default tabs are 'dashboard', 'search', 'upload', 'featured', * 'new', and 'updated'. * @@ -140,11 +145,20 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { ) ); } - function no_items() { + /** + * @access public + */ + public function no_items() { _e( 'No themes match your request.' ); } - function get_views() { + /** + * + * @global array $tabs + * @global string $tab + * @return array + */ + protected function get_views() { global $tabs, $tab; $display_tabs = array(); @@ -157,7 +171,10 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { return $display_tabs; } - function display() { + /** + * @access public + */ + public function display() { wp_nonce_field( "fetch-list-" . get_class( $this ), '_ajax_fetch_list_nonce' ); ?>
@@ -180,10 +197,13 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table {
tablenav( 'bottom' ); } - function display_rows() { + /** + * @access public + */ + public function display_rows() { $themes = $this->items; foreach ( $themes as $theme ) { ?> @@ -198,6 +218,8 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { /** * Prints a theme from the WordPress.org API. * + * @global array $themes_allowedtags + * * @param object $theme An object that contains theme data returned by the WordPress.org API. * * Example theme data: @@ -214,7 +236,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { * public 'description' => string 'A basic magazine style layout with a fully customizable layout through a backend interface. Designed by c.bavota of Tinker Priest Media.' * public 'download_link' => string 'http://wordpress.org/themes/download/magazine-basic.1.1.zip' */ - function single_row( $theme ) { + public function single_row( $theme ) { global $themes_allowedtags; if ( empty( $theme ) ) @@ -244,10 +266,6 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { $status = $this->_get_theme_status( $theme ); switch ( $status ) { - default: - case 'install': - $actions[] = '' . __( 'Install Now' ) . ''; - break; case 'update_available': $actions[] = '' . __( 'Update' ) . ''; break; @@ -255,6 +273,10 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { case 'latest_installed': $actions[] = '' . _x( 'Installed', 'theme' ) . ''; break; + case 'install': + default: + $actions[] = '' . __( 'Install Now' ) . ''; + break; } $actions[] = '' . __( 'Preview' ) . ''; @@ -272,7 +294,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { ?> - +

@@ -294,7 +316,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { /** * Prints the wrapper for the theme installer. */ - function theme_installer() { + public function theme_installer() { ?>
@@ -306,10 +328,10 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table {
@@ -323,7 +345,7 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { * * @param object $theme - A WordPress.org Theme API object. */ - function theme_installer_single( $theme ) { + public function theme_installer_single( $theme ) { ?>
@@ -339,9 +361,11 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { /** * Prints the info for a theme (to be used in the theme installer modal). * + * @global array $themes_allowedtags + * * @param object $theme - A WordPress.org Theme API object. */ - function install_theme_info( $theme ) { + public function install_theme_info( $theme ) { global $themes_allowedtags; if ( empty( $theme ) ) @@ -350,8 +374,6 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { $name = wp_kses( $theme->name, $themes_allowedtags ); $author = wp_kses( $theme->author, $themes_allowedtags ); - $num_ratings = sprintf( _n( '(based on %s rating)', '(based on %s ratings)', $theme->num_ratings ), number_format_i18n( $theme->num_ratings ) ); - $install_url = add_query_arg( array( 'action' => 'install-theme', 'theme' => $theme->slug, @@ -367,10 +389,6 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { ?>
slug ) ) . '">' . __( 'Install' ) . ''; - break; case 'update_available': echo '' . __( 'Update' ) . ''; break; @@ -378,6 +396,10 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { case 'latest_installed': echo '' . _x( 'Installed', 'theme' ) . ''; break; + case 'install': + default: + echo '' . __( 'Install' ) . ''; + break; } ?>

@@ -403,12 +425,14 @@ class WP_Theme_Install_List_Table extends WP_Themes_List_Table { * Send required variables to JavaScript land * * @since 3.4.0 - * @access private + * @access public + * + * @global string $tab Current tab within Themes->Install screen + * @global string $type Type of search. * - * @uses $tab Global; current tab within Themes->Install screen - * @uses $type Global; type of search. + * @param array $extra_args Unused. */ - function _js_vars( $extra_args = array() ) { + public function _js_vars( $extra_args = array() ) { global $tab, $type; parent::_js_vars( compact( 'tab', 'type' ) ); }