2010-10-25 04:57:43 +02:00
< ? php
/**
2015-10-17 17:13:25 +02:00
* List Table API : WP_Plugins_List_Table class
2010-10-25 04:57:43 +02:00
*
* @ package WordPress
2015-10-17 17:13:25 +02:00
* @ subpackage Administration
* @ since 3.1 . 0
*/
/**
* Core class used to implement displaying installed plugins in a list table .
*
2010-10-25 06:04:18 +02:00
* @ since 3.1 . 0
2011-01-16 22:47:24 +01:00
* @ access private
2015-10-17 17:13:25 +02:00
*
* @ see WP_List_Table
2010-10-25 04:57:43 +02:00
*/
2010-11-04 09:07:03 +01:00
class WP_Plugins_List_Table extends WP_List_Table {
2010-10-25 04:57:43 +02:00
2014-08-10 04:18:17 +02:00
/**
* Constructor .
2014-09-04 17:23:16 +02:00
*
2014-08-10 04:18:17 +02:00
* @ since 3.1 . 0
2014-08-10 04:22:16 +02:00
* @ access public
2014-08-10 04:18:17 +02:00
*
* @ see WP_List_Table :: __construct () for more information on default arguments .
*
2015-05-28 23:41:30 +02:00
* @ global string $status
* @ global int $page
*
2014-08-10 04:18:17 +02:00
* @ param array $args An associative array of arguments .
2014-09-04 17:23:16 +02:00
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function __construct ( $args = array () ) {
2010-10-25 04:57:43 +02:00
global $status , $page ;
2012-09-19 14:43:31 +02:00
parent :: __construct ( array (
'plural' => 'plugins' ,
'screen' => isset ( $args [ 'screen' ] ) ? $args [ 'screen' ] : null ,
) );
2011-09-29 07:54:05 +02:00
$status = 'all' ;
2012-04-19 05:41:29 +02:00
if ( isset ( $_REQUEST [ 'plugin_status' ] ) && in_array ( $_REQUEST [ 'plugin_status' ], array ( 'active' , 'inactive' , 'recently_activated' , 'upgrade' , 'mustuse' , 'dropins' , 'search' ) ) )
2011-09-29 07:54:05 +02:00
$status = $_REQUEST [ 'plugin_status' ];
2011-06-01 18:03:41 +02:00
if ( isset ( $_REQUEST [ 's' ]) )
2013-03-01 18:00:25 +01:00
$_SERVER [ 'REQUEST_URI' ] = add_query_arg ( 's' , wp_unslash ( $_REQUEST [ 's' ]) );
2011-06-01 18:03:41 +02:00
2010-11-04 21:49:30 +01:00
$page = $this -> get_pagenum ();
2010-10-25 04:57:43 +02:00
}
2011-06-11 01:01:45 +02:00
2015-05-29 22:17:26 +02:00
/**
* @ return array
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
protected function get_table_classes () {
2011-02-15 04:43:47 +01:00
return array ( 'widefat' , $this -> _args [ 'plural' ] );
}
2010-10-25 04:57:43 +02:00
2015-05-29 22:17:26 +02:00
/**
* @ return bool
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function ajax_user_can () {
2010-12-16 10:18:28 +01:00
return current_user_can ( 'activate_plugins' );
2010-10-25 04:57:43 +02:00
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global string $status
* @ global type $plugins
* @ global array $totals
* @ global int $page
* @ global string $orderby
* @ global string $order
* @ global string $s
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function prepare_items () {
2010-10-25 04:57:43 +02:00
global $status , $plugins , $totals , $page , $orderby , $order , $s ;
2016-01-14 21:06:25 +01:00
wp_reset_vars ( array ( 'orderby' , 'order' ) );
2010-10-25 04:57:43 +02:00
2014-03-02 21:48:14 +01:00
/**
* Filter the full array of plugins to list in the Plugins list table .
*
* @ since 3.0 . 0
*
* @ see get_plugins ()
*
* @ param array $plugins An array of plugins to display in the list table .
*/
2010-10-25 04:57:43 +02:00
$plugins = array (
'all' => apply_filters ( 'all_plugins' , get_plugins () ),
'search' => array (),
'active' => array (),
'inactive' => array (),
'recently_activated' => array (),
'upgrade' => array (),
'mustuse' => array (),
'dropins' => array ()
);
2012-09-19 14:43:31 +02:00
$screen = $this -> screen ;
2010-11-08 16:43:44 +01:00
2013-03-09 04:52:27 +01:00
if ( ! is_multisite () || ( $screen -> in_admin ( 'network' ) && current_user_can ( 'manage_network_plugins' ) ) ) {
2014-03-02 21:48:14 +01:00
/**
* Filter whether to display the advanced plugins list table .
*
* There are two types of advanced plugins - must - use and drop - ins -
* which can be used in a single site or Multisite network .
*
* The $type parameter allows you to differentiate between the type of advanced
* plugins to filter the display of . Contexts include 'mustuse' and 'dropins' .
*
* @ since 3.0 . 0
*
* @ param bool $show Whether to show the advanced plugins for the specified
* plugin type . Default true .
* @ param string $type The plugin type . Accepts 'mustuse' , 'dropins' .
*/
if ( apply_filters ( 'show_advanced_plugins' , true , 'mustuse' ) ) {
2010-10-25 04:57:43 +02:00
$plugins [ 'mustuse' ] = get_mu_plugins ();
2014-03-02 21:48:14 +01:00
}
/** This action is documented in wp-admin/includes/class-wp-plugins-list-table.php */
2010-10-25 04:57:43 +02:00
if ( apply_filters ( 'show_advanced_plugins' , true , 'dropins' ) )
$plugins [ 'dropins' ] = get_dropins ();
2010-11-14 19:34:59 +01:00
2012-03-21 17:19:27 +01:00
if ( current_user_can ( 'update_plugins' ) ) {
$current = get_site_transient ( 'update_plugins' );
foreach ( ( array ) $plugins [ 'all' ] as $plugin_file => $plugin_data ) {
if ( isset ( $current -> response [ $plugin_file ] ) ) {
$plugins [ 'all' ][ $plugin_file ][ 'update' ] = true ;
$plugins [ 'upgrade' ][ $plugin_file ] = $plugins [ 'all' ][ $plugin_file ];
}
}
2010-11-14 19:34:59 +01:00
}
2010-10-25 04:57:43 +02:00
}
2015-10-14 00:12:25 +02:00
if ( ! $screen -> in_admin ( 'network' ) ) {
$show = current_user_can ( 'manage_network_plugins' );
/**
* Filter whether to display network - active plugins alongside plugins active for the current site .
*
* This also controls the display of inactive network - only plugins ( plugins with
* " Network: true " in the plugin header ) .
*
* Plugins cannot be network - activated or network - deactivated from this screen .
*
* @ since 4.4 . 0
*
* @ param bool $show Whether to show network - active plugins . Default is whether the current
* user can manage network plugins ( ie . a Super Admin ) .
*/
$show_network_active = apply_filters ( 'show_network_active_plugins' , $show );
}
2012-09-25 07:26:19 +02:00
set_transient ( 'plugin_slugs' , array_keys ( $plugins [ 'all' ] ), DAY_IN_SECONDS );
2010-10-25 04:57:43 +02:00
2015-09-25 21:16:27 +02:00
if ( $screen -> in_admin ( 'network' ) ) {
2015-10-07 19:11:25 +02:00
$recently_activated = get_site_option ( 'recently_activated' , array () );
2015-09-25 21:16:27 +02:00
} else {
2012-04-19 05:41:29 +02:00
$recently_activated = get_option ( 'recently_activated' , array () );
2015-09-25 21:16:27 +02:00
}
foreach ( $recently_activated as $key => $time ) {
if ( $time + WEEK_IN_SECONDS < time () ) {
unset ( $recently_activated [ $key ] );
}
}
2010-10-25 04:57:43 +02:00
2015-09-25 21:16:27 +02:00
if ( $screen -> in_admin ( 'network' ) ) {
2015-10-07 19:11:25 +02:00
update_site_option ( 'recently_activated' , $recently_activated );
2015-09-25 21:16:27 +02:00
} else {
2012-04-19 05:41:29 +02:00
update_option ( 'recently_activated' , $recently_activated );
}
2014-08-09 16:46:17 +02:00
2014-07-18 22:49:17 +02:00
$plugin_info = get_site_transient ( 'update_plugins' );
2010-10-25 04:57:43 +02:00
foreach ( ( array ) $plugins [ 'all' ] as $plugin_file => $plugin_data ) {
2014-07-18 22:49:17 +02:00
// Extra info if known. array_merge() ensures $plugin_data has precedence if keys collide.
if ( isset ( $plugin_info -> response [ $plugin_file ] ) ) {
$plugins [ 'all' ][ $plugin_file ] = $plugin_data = array_merge ( ( array ) $plugin_info -> response [ $plugin_file ], $plugin_data );
2015-03-24 18:33:27 +01:00
// Make sure that $plugins['upgrade'] also receives the extra info since it is used on ?plugin_status=upgrade
if ( isset ( $plugins [ 'upgrade' ][ $plugin_file ] ) ) {
2015-03-24 18:30:26 +01:00
$plugins [ 'upgrade' ][ $plugin_file ] = $plugin_data = array_merge ( ( array ) $plugin_info -> response [ $plugin_file ], $plugin_data );
}
2014-07-18 22:49:17 +02:00
} elseif ( isset ( $plugin_info -> no_update [ $plugin_file ] ) ) {
$plugins [ 'all' ][ $plugin_file ] = $plugin_data = array_merge ( ( array ) $plugin_info -> no_update [ $plugin_file ], $plugin_data );
2015-03-24 18:33:27 +01:00
// Make sure that $plugins['upgrade'] also receives the extra info since it is used on ?plugin_status=upgrade
if ( isset ( $plugins [ 'upgrade' ][ $plugin_file ] ) ) {
2015-03-24 18:30:26 +01:00
$plugins [ 'upgrade' ][ $plugin_file ] = $plugin_data = array_merge ( ( array ) $plugin_info -> no_update [ $plugin_file ], $plugin_data );
}
2014-07-18 22:49:17 +02:00
}
2010-10-25 04:57:43 +02:00
// Filter into individual sections
2014-02-28 21:22:14 +01:00
if ( is_multisite () && ! $screen -> in_admin ( 'network' ) && is_network_only_plugin ( $plugin_file ) && ! is_plugin_active ( $plugin_file ) ) {
2015-10-14 00:12:25 +02:00
if ( $show_network_active ) {
// On the non-network screen, show inactive network-only plugins if allowed
$plugins [ 'inactive' ][ $plugin_file ] = $plugin_data ;
} else {
// On the non-network screen, filter out network-only plugins as long as they're not individually active
unset ( $plugins [ 'all' ][ $plugin_file ] );
}
2013-03-09 04:52:27 +01:00
} elseif ( ! $screen -> in_admin ( 'network' ) && is_plugin_active_for_network ( $plugin_file ) ) {
2015-10-14 00:12:25 +02:00
if ( $show_network_active ) {
// On the non-network screen, show network-active plugins if allowed
$plugins [ 'active' ][ $plugin_file ] = $plugin_data ;
} else {
// On the non-network screen, filter out network-active plugins
unset ( $plugins [ 'all' ][ $plugin_file ] );
}
2013-03-09 04:52:27 +01:00
} elseif ( ( ! $screen -> in_admin ( 'network' ) && is_plugin_active ( $plugin_file ) )
|| ( $screen -> in_admin ( 'network' ) && is_plugin_active_for_network ( $plugin_file ) ) ) {
2014-02-28 21:22:14 +01:00
// On the non-network screen, populate the active list with plugins that are individually activated
// On the network-admin screen, populate the active list with plugins that are network activated
2010-10-25 04:57:43 +02:00
$plugins [ 'active' ][ $plugin_file ] = $plugin_data ;
} else {
2015-09-25 21:16:27 +02:00
if ( isset ( $recently_activated [ $plugin_file ] ) ) {
// Populate the recently activated list with plugins that have been recently activated
2010-10-25 04:57:43 +02:00
$plugins [ 'recently_activated' ][ $plugin_file ] = $plugin_data ;
2014-02-28 21:22:14 +01:00
}
// Populate the inactive list with plugins that aren't activated
2010-10-25 04:57:43 +02:00
$plugins [ 'inactive' ][ $plugin_file ] = $plugin_data ;
}
}
2016-01-14 21:06:25 +01:00
if ( strlen ( $s ) ) {
2010-10-25 04:57:43 +02:00
$status = 'search' ;
2013-09-05 18:34:09 +02:00
$plugins [ 'search' ] = array_filter ( $plugins [ 'all' ], array ( $this , '_search_callback' ) );
2010-10-25 04:57:43 +02:00
}
$totals = array ();
foreach ( $plugins as $type => $list )
$totals [ $type ] = count ( $list );
if ( empty ( $plugins [ $status ] ) && ! in_array ( $status , array ( 'all' , 'search' ) ) )
$status = 'all' ;
2010-11-14 19:34:59 +01:00
$this -> items = array ();
foreach ( $plugins [ $status ] as $plugin_file => $plugin_data ) {
2010-12-16 09:04:54 +01:00
// Translate, Don't Apply Markup, Sanitize HTML
2010-11-14 19:34:59 +01:00
$this -> items [ $plugin_file ] = _get_plugin_data_markup_translate ( $plugin_file , $plugin_data , false , true );
}
2010-10-25 04:57:43 +02:00
$total_this_page = $totals [ $status ];
2015-07-01 00:31:25 +02:00
if ( ! $orderby ) {
$orderby = 'Name' ;
} else {
2010-10-25 04:57:43 +02:00
$orderby = ucfirst ( $orderby );
}
2015-07-01 00:31:25 +02:00
$order = strtoupper ( $order );
uasort ( $this -> items , array ( $this , '_order_callback' ) );
2011-06-18 17:02:58 +02:00
$plugins_per_page = $this -> get_items_per_page ( str_replace ( '-' , '_' , $screen -> id . '_per_page' ), 999 );
2010-10-25 04:57:43 +02:00
$start = ( $page - 1 ) * $plugins_per_page ;
if ( $total_this_page > $plugins_per_page )
$this -> items = array_slice ( $this -> items , $start , $plugins_per_page );
$this -> set_pagination_args ( array (
'total_items' => $total_this_page ,
'per_page' => $plugins_per_page ,
) );
}
2014-12-01 01:33:23 +01:00
/**
2016-01-14 21:06:25 +01:00
* @ global string $s
*
2014-12-01 01:33:23 +01:00
* @ param array $plugin
2015-05-29 22:17:26 +02:00
* @ return bool
2014-12-01 01:33:23 +01:00
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function _search_callback ( $plugin ) {
2016-01-14 21:06:25 +01:00
global $s ;
2010-10-25 04:57:43 +02:00
2014-03-11 23:24:15 +01:00
foreach ( $plugin as $value ) {
2016-01-14 21:06:25 +01:00
if ( is_string ( $value ) && false !== stripos ( strip_tags ( $value ), $s ) ) {
2010-10-25 04:57:43 +02:00
return true ;
2014-03-11 23:24:15 +01:00
}
}
2010-10-25 04:57:43 +02:00
return false ;
}
2014-12-01 01:33:23 +01:00
/**
* @ global string $orderby
* @ global string $order
* @ param array $plugin_a
* @ param array $plugin_b
* @ return int
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function _order_callback ( $plugin_a , $plugin_b ) {
2010-10-25 04:57:43 +02:00
global $orderby , $order ;
$a = $plugin_a [ $orderby ];
$b = $plugin_b [ $orderby ];
if ( $a == $b )
return 0 ;
2015-09-22 08:06:25 +02:00
if ( 'DESC' === $order ) {
2015-07-03 23:53:25 +02:00
return strcasecmp ( $b , $a );
} else {
return strcasecmp ( $a , $b );
}
2010-10-25 04:57:43 +02:00
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global array $plugins
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function no_items () {
2010-10-25 04:57:43 +02:00
global $plugins ;
2015-12-06 23:23:25 +01:00
if ( ! empty ( $_REQUEST [ 's' ] ) ) {
$s = esc_html ( $_REQUEST [ 's' ] );
printf ( __ ( 'No plugins found for “%s”.' ), $s );
// We assume that somebody who can install plugins in multisite is experienced enough to not need this helper link.
if ( ! is_multisite () && current_user_can ( 'install_plugins' ) ) {
echo ' <a href="' . esc_url ( admin_url ( 'plugin-install.php?tab=search&s=' . urlencode ( $s ) ) ) . '">' . __ ( 'Search for plugins in the WordPress Plugin Directory.' ) . '</a>' ;
}
} elseif ( ! empty ( $plugins [ 'all' ] ) )
2010-10-25 04:57:43 +02:00
_e ( 'No plugins found.' );
else
_e ( 'You do not appear to have any plugins available at this time.' );
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global string $status
* @ return array
*/
2014-07-12 05:27:14 +02:00
public function get_columns () {
2010-10-25 04:57:43 +02:00
global $status ;
return array (
'cb' => ! in_array ( $status , array ( 'mustuse' , 'dropins' ) ) ? '<input type="checkbox" />' : '' ,
'name' => __ ( 'Plugin' ),
'description' => __ ( 'Description' ),
);
}
2015-05-29 22:17:26 +02:00
/**
* @ return array
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
protected function get_sortable_columns () {
2011-01-20 23:09:46 +01:00
return array ();
2010-10-25 04:57:43 +02:00
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global array $totals
* @ global string $status
* @ return array
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
protected function get_views () {
2010-10-25 04:57:43 +02:00
global $totals , $status ;
$status_links = array ();
foreach ( $totals as $type => $count ) {
if ( ! $count )
continue ;
switch ( $type ) {
case 'all' :
$text = _nx ( 'All <span class="count">(%s)</span>' , 'All <span class="count">(%s)</span>' , $count , 'plugins' );
break ;
case 'active' :
$text = _n ( 'Active <span class="count">(%s)</span>' , 'Active <span class="count">(%s)</span>' , $count );
break ;
case 'recently_activated' :
$text = _n ( 'Recently Active <span class="count">(%s)</span>' , 'Recently Active <span class="count">(%s)</span>' , $count );
break ;
case 'inactive' :
$text = _n ( 'Inactive <span class="count">(%s)</span>' , 'Inactive <span class="count">(%s)</span>' , $count );
break ;
case 'mustuse' :
$text = _n ( 'Must-Use <span class="count">(%s)</span>' , 'Must-Use <span class="count">(%s)</span>' , $count );
break ;
case 'dropins' :
$text = _n ( 'Drop-ins <span class="count">(%s)</span>' , 'Drop-ins <span class="count">(%s)</span>' , $count );
break ;
case 'upgrade' :
2010-12-02 22:45:47 +01:00
$text = _n ( 'Update Available <span class="count">(%s)</span>' , 'Update Available <span class="count">(%s)</span>' , $count );
2010-10-25 04:57:43 +02:00
break ;
}
2011-01-06 05:11:14 +01:00
2015-09-22 08:06:25 +02:00
if ( 'search' !== $type ) {
2010-12-18 00:47:40 +01:00
$status_links [ $type ] = sprintf ( " <a href='%s' %s>%s</a> " ,
add_query_arg ( 'plugin_status' , $type , 'plugins.php' ),
2015-09-22 08:06:25 +02:00
( $type === $status ) ? ' class="current"' : '' ,
2010-12-18 00:47:40 +01:00
sprintf ( $text , number_format_i18n ( $count ) )
);
}
2010-10-25 04:57:43 +02:00
}
return $status_links ;
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global string $status
* @ return array
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
protected function get_bulk_actions () {
2010-10-25 04:57:43 +02:00
global $status ;
$actions = array ();
2010-10-29 21:09:04 +02:00
2012-04-19 05:41:29 +02:00
if ( 'active' != $status )
2013-03-09 04:52:27 +01:00
$actions [ 'activate-selected' ] = $this -> screen -> in_admin ( 'network' ) ? __ ( 'Network Activate' ) : __ ( 'Activate' );
2010-10-29 21:09:04 +02:00
2010-10-25 04:57:43 +02:00
if ( 'inactive' != $status && 'recent' != $status )
2013-03-09 04:52:27 +01:00
$actions [ 'deactivate-selected' ] = $this -> screen -> in_admin ( 'network' ) ? __ ( 'Network Deactivate' ) : __ ( 'Deactivate' );
2010-10-29 21:09:04 +02:00
2013-03-09 04:52:27 +01:00
if ( ! is_multisite () || $this -> screen -> in_admin ( 'network' ) ) {
2010-10-29 21:09:04 +02:00
if ( current_user_can ( 'update_plugins' ) )
$actions [ 'update-selected' ] = __ ( 'Update' );
if ( current_user_can ( 'delete_plugins' ) && ( 'active' != $status ) )
$actions [ 'delete-selected' ] = __ ( 'Delete' );
2010-10-28 10:30:37 +02:00
}
2010-10-25 04:57:43 +02:00
return $actions ;
}
2014-12-01 01:33:23 +01:00
/**
* @ global string $status
* @ param string $which
*/
2014-08-09 16:46:17 +02:00
public function bulk_actions ( $which = '' ) {
2010-10-25 04:57:43 +02:00
global $status ;
if ( in_array ( $status , array ( 'mustuse' , 'dropins' ) ) )
return ;
2014-07-25 02:20:16 +02:00
parent :: bulk_actions ( $which );
2010-10-25 04:57:43 +02:00
}
2014-12-01 01:33:23 +01:00
/**
* @ global string $status
* @ param string $which
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
protected function extra_tablenav ( $which ) {
2010-10-25 04:57:43 +02:00
global $status ;
2011-05-05 07:24:15 +02:00
if ( ! in_array ( $status , array ( 'recently_activated' , 'mustuse' , 'dropins' ) ) )
return ;
echo '<div class="alignleft actions">' ;
2015-09-25 21:16:27 +02:00
if ( 'recently_activated' == $status ) {
2012-11-28 23:20:45 +01:00
submit_button ( __ ( 'Clear List' ), 'button' , 'clear-recent-list' , false );
2015-09-22 08:06:25 +02:00
} elseif ( 'top' === $which && 'mustuse' === $status ) {
2015-10-30 02:08:25 +01:00
/* translators: %s: mu-plugins directory name */
echo '<p>' . sprintf ( __ ( 'Files in the %s directory are executed automatically.' ),
'<code>' . str_replace ( ABSPATH , '/' , WPMU_PLUGIN_DIR ) . '</code>'
) . '</p>' ;
2015-09-22 08:06:25 +02:00
} elseif ( 'top' === $which && 'dropins' === $status ) {
2015-10-30 02:08:25 +01:00
/* translators: %s: wp-content directory name */
echo '<p>' . sprintf ( __ ( 'Drop-ins are advanced plugins in the %s directory that replace WordPress functionality when present.' ),
'<code>' . str_replace ( ABSPATH , '' , WP_CONTENT_DIR ) . '</code>'
) . '</p>' ;
2015-09-22 08:06:25 +02:00
}
2011-05-05 07:24:15 +02:00
echo '</div>' ;
2010-10-25 04:57:43 +02:00
}
2015-05-29 22:17:26 +02:00
/**
* @ return string
*/
Add access modifiers to methods and members of list table classes:
* `WP_List_Table` is the base class that implements `__get()` and `__call()` for BC
* Adds unit tests to confirm that subclasses properly inherit magic methods
* Add modifiers to subclasses: `WP_Links_List_Table`, `WP_Media_List_Table`, `WP_MS_Sites_List_Table`, `WP_MS_Themes_List_Table`, `WP_MS_Users_List_Table`, `WP_Plugin_Install_List_Table`, `WP_Plugins_List_Table`, `WP_Posts_List_Table`, `WP_Terms_List_Table`, `WP_Theme_Install_List_Table`, `WP_Themes_List_Table`
See #27881, #22234.
Built from https://develop.svn.wordpress.org/trunk@28493
git-svn-id: http://core.svn.wordpress.org/trunk@28319 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2014-05-19 03:17:15 +02:00
public function current_action () {
2010-10-25 04:57:43 +02:00
if ( isset ( $_POST [ 'clear-recent-list' ]) )
return 'clear-recent-list' ;
return parent :: current_action ();
}
2015-05-28 23:41:30 +02:00
/**
*
* @ global string $status
*/
2014-07-14 00:09:16 +02:00
public function display_rows () {
2010-11-13 17:30:20 +01:00
global $status ;
2013-03-09 04:52:27 +01:00
if ( is_multisite () && ! $this -> screen -> in_admin ( 'network' ) && in_array ( $status , array ( 'mustuse' , 'dropins' ) ) )
2010-11-13 17:30:20 +01:00
return ;
foreach ( $this -> items as $plugin_file => $plugin_data )
2012-11-05 19:29:20 +01:00
$this -> single_row ( array ( $plugin_file , $plugin_data ) );
2010-11-13 17:30:20 +01:00
}
2014-12-01 01:33:23 +01:00
/**
* @ global string $status
* @ global int $page
* @ global string $s
* @ global array $totals
2015-07-05 17:03:25 +02:00
*
2014-12-01 01:33:23 +01:00
* @ param array $item
*/
2014-07-14 00:09:16 +02:00
public function single_row ( $item ) {
2012-03-21 17:19:27 +01:00
global $status , $page , $s , $totals ;
2010-10-25 04:57:43 +02:00
2012-11-05 19:29:20 +01:00
list ( $plugin_file , $plugin_data ) = $item ;
2010-10-25 04:57:43 +02:00
$context = $status ;
2012-09-19 14:43:31 +02:00
$screen = $this -> screen ;
2010-11-08 16:43:44 +01:00
2014-07-17 11:14:16 +02:00
// Pre-order.
2010-11-13 17:30:20 +01:00
$actions = array (
2012-04-19 05:41:29 +02:00
'deactivate' => '' ,
'activate' => '' ,
2014-07-18 22:49:17 +02:00
'details' => '' ,
2010-11-13 17:30:20 +01:00
'edit' => '' ,
'delete' => '' ,
);
2010-10-25 04:57:43 +02:00
2015-10-22 21:56:23 +02:00
// Do not restrict by default
$restrict_network_active = false ;
$restrict_network_only = false ;
2015-09-22 08:06:25 +02:00
if ( 'mustuse' === $context ) {
2010-11-13 17:30:20 +01:00
$is_active = true ;
2015-09-22 08:06:25 +02:00
} elseif ( 'dropins' === $context ) {
2010-11-13 17:30:20 +01:00
$dropins = _get_dropins ();
$plugin_name = $plugin_file ;
if ( $plugin_file != $plugin_data [ 'Name' ] )
$plugin_name .= '<br/>' . $plugin_data [ 'Name' ];
if ( true === ( $dropins [ $plugin_file ][ 1 ] ) ) { // Doesn't require a constant
2010-10-25 04:57:43 +02:00
$is_active = true ;
2010-11-13 17:30:20 +01:00
$description = '<p><strong>' . $dropins [ $plugin_file ][ 0 ] . '</strong></p>' ;
2013-09-13 11:37:10 +02:00
} elseif ( defined ( $dropins [ $plugin_file ][ 1 ] ) && constant ( $dropins [ $plugin_file ][ 1 ] ) ) { // Constant is true
2010-11-13 17:30:20 +01:00
$is_active = true ;
$description = '<p><strong>' . $dropins [ $plugin_file ][ 0 ] . '</strong></p>' ;
} else {
$is_active = false ;
2015-10-30 02:08:25 +01:00
$description = '<p><strong>' . $dropins [ $plugin_file ][ 0 ] . ' <span class="error-message">' . __ ( 'Inactive:' ) . '</span></strong> ' .
2015-10-30 02:56:25 +01:00
/* translators: 1: drop-in constant name, 2: wp-config.php */
sprintf ( __ ( 'Requires %1$s in %2$s file.' ),
" <code>define(' " . $dropins [ $plugin_file ][ 1 ] . " ', true);</code> " ,
'<code>wp-config.php</code>'
2015-10-30 02:08:25 +01:00
) . '</p>' ;
2010-11-13 17:30:20 +01:00
}
if ( $plugin_data [ 'Description' ] )
$description .= '<p>' . $plugin_data [ 'Description' ] . '</p>' ;
} else {
2015-10-14 00:12:25 +02:00
if ( $screen -> in_admin ( 'network' ) ) {
2012-04-19 05:41:29 +02:00
$is_active = is_plugin_active_for_network ( $plugin_file );
2015-10-14 00:12:25 +02:00
} else {
2010-11-13 17:30:20 +01:00
$is_active = is_plugin_active ( $plugin_file );
2015-10-14 00:12:25 +02:00
$restrict_network_active = ( is_multisite () && is_plugin_active_for_network ( $plugin_file ) );
$restrict_network_only = ( is_multisite () && is_network_only_plugin ( $plugin_file ) && ! $is_active );
}
2010-11-13 17:30:20 +01:00
2013-03-09 04:52:27 +01:00
if ( $screen -> in_admin ( 'network' ) ) {
2012-04-19 05:41:29 +02:00
if ( $is_active ) {
2015-07-05 17:03:25 +02:00
if ( current_user_can ( 'manage_network_plugins' ) ) {
/* translators: %s: plugin name */
$actions [ 'deactivate' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=deactivate&plugin=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'deactivate-plugin_' . $plugin_file ) . '" aria-label="' . esc_attr ( sprintf ( __ ( 'Network deactivate %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Network Deactivate' ) . '</a>' ;
}
2010-10-25 04:57:43 +02:00
} else {
2015-07-05 17:03:25 +02:00
if ( current_user_can ( 'manage_network_plugins' ) ) {
/* translators: %s: plugin name */
$actions [ 'activate' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=activate&plugin=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'activate-plugin_' . $plugin_file ) . '" class="edit" aria-label="' . esc_attr ( sprintf ( __ ( 'Network Activate %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Network Activate' ) . '</a>' ;
}
if ( current_user_can ( 'delete_plugins' ) && ! is_plugin_active ( $plugin_file ) ) {
/* translators: %s: plugin name */
$actions [ 'delete' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=delete-selected&checked[]=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'bulk-plugins' ) . '" class="delete" aria-label="' . esc_attr ( sprintf ( __ ( 'Delete %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Delete' ) . '</a>' ;
}
2010-10-25 04:57:43 +02:00
}
} else {
2015-10-14 00:12:25 +02:00
if ( $restrict_network_active ) {
$actions = array (
'network_active' => __ ( 'Network Active' ),
);
} elseif ( $restrict_network_only ) {
$actions = array (
'network_only' => __ ( 'Network Only' ),
);
} elseif ( $is_active ) {
2015-07-05 17:03:25 +02:00
/* translators: %s: plugin name */
$actions [ 'deactivate' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=deactivate&plugin=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'deactivate-plugin_' . $plugin_file ) . '" aria-label="' . esc_attr ( sprintf ( __ ( 'Deactivate %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Deactivate' ) . '</a>' ;
2010-10-25 04:57:43 +02:00
} else {
2015-07-05 17:03:25 +02:00
/* translators: %s: plugin name */
$actions [ 'activate' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=activate&plugin=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'activate-plugin_' . $plugin_file ) . '" class="edit" aria-label="' . esc_attr ( sprintf ( __ ( 'Activate %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Activate' ) . '</a>' ;
2010-11-13 17:30:20 +01:00
2015-07-05 17:03:25 +02:00
if ( ! is_multisite () && current_user_can ( 'delete_plugins' ) ) {
/* translators: %s: plugin name */
$actions [ 'delete' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=delete-selected&checked[]=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'bulk-plugins' ) . '" class="delete" aria-label="' . esc_attr ( sprintf ( __ ( 'Delete %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Delete' ) . '</a>' ;
}
2010-11-13 17:30:20 +01:00
} // end if $is_active
2014-08-09 16:46:17 +02:00
2013-03-09 04:52:27 +01:00
} // end if $screen->in_admin( 'network' )
2010-11-13 17:30:20 +01:00
2015-07-05 17:03:25 +02:00
if ( ( ! is_multisite () || $screen -> in_admin ( 'network' ) ) && current_user_can ( 'edit_plugins' ) && is_writable ( WP_PLUGIN_DIR . '/' . $plugin_file ) ) {
/* translators: %s: plugin name */
$actions [ 'edit' ] = '<a href="plugin-editor.php?file=' . $plugin_file . '" class="edit" aria-label="' . esc_attr ( sprintf ( __ ( 'Edit %s' ), $plugin_data [ 'Name' ] ) ) . '">' . __ ( 'Edit' ) . '</a>' ;
}
2010-11-13 17:30:20 +01:00
} // end if $context
2015-10-03 01:44:26 +02:00
$actions = array_filter ( $actions );
2014-03-02 21:48:14 +01:00
2015-10-03 01:44:26 +02:00
if ( $screen -> in_admin ( 'network' ) ) {
2014-03-02 21:48:14 +01:00
2015-10-03 01:44:26 +02:00
/**
* Filter the action links displayed for each plugin in the Network Admin Plugins list table .
*
* The default action links for the Network plugins list table include
* 'Network Activate' , 'Network Deactivate' , 'Edit' , and 'Delete' .
*
* @ since 3.1 . 0 As `{$prefix}_plugin_action_links`
* @ since 4.4 . 0
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $context The plugin context . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' ,
* 'Must-Use' , 'Drop-ins' , 'Search' .
*/
$actions = apply_filters ( 'network_admin_plugin_action_links' , $actions , $plugin_file , $plugin_data , $context );
/**
* Filter the list of action links displayed for a specific plugin in the Network Admin Plugins list table .
*
* The dynamic portion of the hook name , $plugin_file , refers to the path
* to the plugin file , relative to the plugins directory .
*
* @ since 3.1 . 0 As `{$prefix}_plugin_action_links_{$plugin_file}`
* @ since 4.4 . 0
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $context The plugin context . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' ,
* 'Must-Use' , 'Drop-ins' , 'Search' .
*/
$actions = apply_filters ( " network_admin_plugin_action_links_ { $plugin_file } " , $actions , $plugin_file , $plugin_data , $context );
} else {
/**
* Filter the action links displayed for each plugin in the Plugins list table .
*
* The default action links for the site plugins list table include
* 'Activate' , 'Deactivate' , and 'Edit' , for a network site , and
* 'Activate' , 'Deactivate' , 'Edit' , and 'Delete' for a single site .
*
* @ since 2.5 . 0 As `{$prefix}_plugin_action_links`
* @ since 4.4 . 0
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $context The plugin context . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' ,
* 'Must-Use' , 'Drop-ins' , 'Search' .
*/
$actions = apply_filters ( 'plugin_action_links' , $actions , $plugin_file , $plugin_data , $context );
/**
* Filter the list of action links displayed for a specific plugin in the Plugins list table .
*
* The dynamic portion of the hook name , $plugin_file , refers to the path
* to the plugin file , relative to the plugins directory .
*
* @ since 2.7 . 0 As `{$prefix}_plugin_action_links_{$plugin_file}`
* @ since 4.4 . 0
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $context The plugin context . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' ,
* 'Must-Use' , 'Drop-ins' , 'Search' .
*/
$actions = apply_filters ( " plugin_action_links_ { $plugin_file } " , $actions , $plugin_file , $plugin_data , $context );
}
2010-11-13 17:30:20 +01:00
$class = $is_active ? 'active' : 'inactive' ;
2010-12-24 15:19:41 +01:00
$checkbox_id = " checkbox_ " . md5 ( $plugin_data [ 'Name' ]);
2015-10-14 00:12:25 +02:00
if ( $restrict_network_active || $restrict_network_only || in_array ( $status , array ( 'mustuse' , 'dropins' ) ) ) {
2012-07-25 18:18:14 +02:00
$checkbox = '' ;
} else {
$checkbox = " <label class='screen-reader-text' for=' " . $checkbox_id . " ' > " . sprintf ( __ ( 'Select %s' ), $plugin_data [ 'Name' ] ) . " </label> "
. " <input type='checkbox' name='checked[]' value=' " . esc_attr ( $plugin_file ) . " ' id=' " . $checkbox_id . " ' /> " ;
}
2010-11-13 17:57:25 +01:00
if ( 'dropins' != $context ) {
2010-12-06 16:15:09 +01:00
$description = '<p>' . ( $plugin_data [ 'Description' ] ? $plugin_data [ 'Description' ] : ' ' ) . '</p>' ;
2010-11-13 17:30:20 +01:00
$plugin_name = $plugin_data [ 'Name' ];
}
2012-03-21 17:19:27 +01:00
if ( ! empty ( $totals [ 'upgrade' ] ) && ! empty ( $plugin_data [ 'update' ] ) )
$class .= ' update' ;
2010-11-13 17:30:20 +01:00
2016-01-06 23:40:26 +01:00
$plugin_slug = isset ( $plugin_data [ 'slug' ] ) ? $plugin_data [ 'slug' ] : sanitize_title ( $plugin_name );
printf ( '<tr class="%s" data-slug="%s" data-plugin="%s">' ,
esc_attr ( $class ),
esc_attr ( $plugin_slug ),
esc_attr ( $plugin_file )
2015-03-19 06:26:28 +01:00
);
2010-11-13 17:30:20 +01:00
2015-05-29 04:41:25 +02:00
list ( $columns , $hidden , $sortable , $primary ) = $this -> get_column_info ();
2010-11-13 17:57:25 +01:00
foreach ( $columns as $column_name => $column_display_name ) {
2015-06-10 21:47:27 +02:00
$extra_classes = '' ;
2015-05-29 04:41:25 +02:00
if ( in_array ( $column_name , $hidden ) ) {
2015-06-10 21:47:27 +02:00
$extra_classes = ' hidden' ;
2015-05-29 04:41:25 +02:00
}
2010-11-13 17:57:25 +01:00
switch ( $column_name ) {
case 'cb' :
echo " <th scope='row' class='check-column'> $checkbox </th> " ;
break ;
case 'name' :
2015-06-10 21:47:27 +02:00
echo " <td class='plugin-title column-primary'><strong> $plugin_name </strong> " ;
2015-06-10 21:31:25 +02:00
echo $this -> row_actions ( $actions , true );
2010-11-13 17:57:25 +01:00
echo " </td> " ;
break ;
case 'description' :
2015-05-29 04:41:25 +02:00
$classes = 'column-description desc' ;
2015-06-10 21:47:27 +02:00
echo " <td class=' $classes { $extra_classes } '>
2010-11-13 17:57:25 +01:00
< div class = 'plugin-description' > $description </ div >
< div class = '$class second plugin-version-author-uri' > " ;
$plugin_meta = array ();
if ( ! empty ( $plugin_data [ 'Version' ] ) )
$plugin_meta [] = sprintf ( __ ( 'Version %s' ), $plugin_data [ 'Version' ] );
if ( ! empty ( $plugin_data [ 'Author' ] ) ) {
$author = $plugin_data [ 'Author' ];
if ( ! empty ( $plugin_data [ 'AuthorURI' ] ) )
2014-06-05 06:52:16 +02:00
$author = '<a href="' . $plugin_data [ 'AuthorURI' ] . '">' . $plugin_data [ 'Author' ] . '</a>' ;
2010-11-13 17:57:25 +01:00
$plugin_meta [] = sprintf ( __ ( 'By %s' ), $author );
}
2014-08-04 20:49:17 +02:00
2014-08-25 17:28:17 +02:00
// Details link using API info, if available
if ( isset ( $plugin_data [ 'slug' ] ) && current_user_can ( 'install_plugins' ) ) {
$plugin_meta [] = sprintf ( '<a href="%s" class="thickbox" aria-label="%s" data-title="%s">%s</a>' ,
esc_url ( network_admin_url ( 'plugin-install.php?tab=plugin-information&plugin=' . $plugin_data [ 'slug' ] .
'&TB_iframe=true&width=600&height=550' ) ),
esc_attr ( sprintf ( __ ( 'More information about %s' ), $plugin_name ) ),
esc_attr ( $plugin_name ),
__ ( 'View details' )
);
} elseif ( ! empty ( $plugin_data [ 'PluginURI' ] ) ) {
$plugin_meta [] = sprintf ( '<a href="%s">%s</a>' ,
esc_url ( $plugin_data [ 'PluginURI' ] ),
__ ( 'Visit plugin site' )
);
2014-08-04 20:49:17 +02:00
}
2010-11-17 19:47:34 +01:00
2014-03-02 21:48:14 +01:00
/**
* Filter the array of row meta for each plugin in the Plugins list table .
*
* @ since 2.8 . 0
*
* @ param array $plugin_meta An array of the plugin ' s metadata ,
* including the version , author ,
* author URI , and plugin URI .
* @ param string $plugin_file Path to the plugin file , relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $status Status of the plugin . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' , 'Must-Use' ,
* 'Drop-ins' , 'Search' .
*/
2010-11-13 17:57:25 +01:00
$plugin_meta = apply_filters ( 'plugin_row_meta' , $plugin_meta , $plugin_file , $plugin_data , $status );
echo implode ( ' | ' , $plugin_meta );
2010-11-13 17:30:20 +01:00
2010-11-13 17:57:25 +01:00
echo " </div></td> " ;
break ;
default :
2015-05-29 04:41:25 +02:00
$classes = " $column_name column- $column_name $class " ;
2015-06-10 21:47:27 +02:00
echo " <td class=' $classes { $extra_classes } '> " ;
2014-03-02 21:48:14 +01:00
/**
* Fires inside each custom column of the Plugins list table .
*
* @ since 3.1 . 0
*
* @ param string $column_name Name of the column .
* @ param string $plugin_file Path to the plugin file .
* @ param array $plugin_data An array of plugin data .
*/
2010-11-13 18:01:57 +01:00
do_action ( 'manage_plugins_custom_column' , $column_name , $plugin_file , $plugin_data );
2015-05-29 04:41:25 +02:00
2010-11-13 17:57:25 +01:00
echo " </td> " ;
}
}
echo " </tr> " ;
2010-10-25 04:57:43 +02:00
2014-03-02 21:48:14 +01:00
/**
* Fires after each row in the Plugins list table .
*
* @ since 2.3 . 0
*
* @ param string $plugin_file Path to the plugin file , relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $status Status of the plugin . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' , 'Must-Use' ,
* 'Drop-ins' , 'Search' .
*/
2010-11-13 17:30:20 +01:00
do_action ( 'after_plugin_row' , $plugin_file , $plugin_data , $status );
2014-03-02 21:48:14 +01:00
/**
* Fires after each specific row in the Plugins list table .
*
2014-11-30 12:28:24 +01:00
* The dynamic portion of the hook name , `$plugin_file` , refers to the path
2014-03-02 21:48:14 +01:00
* to the plugin file , relative to the plugins directory .
*
* @ since 2.7 . 0
*
* @ param string $plugin_file Path to the plugin file , relative to the plugins directory .
* @ param array $plugin_data An array of plugin data .
* @ param string $status Status of the plugin . Defaults are 'All' , 'Active' ,
* 'Inactive' , 'Recently Activated' , 'Upgrade' , 'Must-Use' ,
* 'Drop-ins' , 'Search' .
*/
2010-11-13 17:30:20 +01:00
do_action ( " after_plugin_row_ $plugin_file " , $plugin_file , $plugin_data , $status );
2010-10-25 04:57:43 +02:00
}
2015-05-29 04:41:25 +02:00
/**
2015-07-13 19:46:26 +02:00
* Gets the name of the primary column for this specific list table .
2015-05-29 04:41:25 +02:00
*
* @ since 4.3 . 0
* @ access protected
*
2015-06-10 21:31:25 +02:00
* @ return string Unalterable name for the primary column , in this case , 'name' .
2015-05-29 04:41:25 +02:00
*/
2015-09-14 22:29:26 +02:00
protected function get_primary_column_name () {
2015-06-10 21:31:25 +02:00
return 'name' ;
2015-05-29 04:41:25 +02:00
}
2010-10-25 04:57:43 +02:00
}