2010-10-25 04:57:43 +02:00
< ? php
/**
2010-10-25 06:04:18 +02:00
* Plugins List Table class .
2010-10-25 04:57:43 +02:00
*
* @ package WordPress
2010-10-25 06:04:18 +02:00
* @ subpackage List_Table
* @ since 3.1 . 0
2011-01-16 22:47:24 +01:00
* @ access private
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 .
*
* @ 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
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
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
}
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 ;
wp_reset_vars ( array ( 'orderby' , 'order' , 's' ) );
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
}
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
2013-03-09 04:52:27 +01:00
if ( ! $screen -> in_admin ( 'network' ) ) {
2012-04-19 05:41:29 +02:00
$recently_activated = get_option ( 'recently_activated' , array () );
2010-10-25 04:57:43 +02:00
2012-04-19 05:41:29 +02:00
foreach ( $recently_activated as $key => $time )
2012-09-25 07:26:19 +02:00
if ( $time + WEEK_IN_SECONDS < time () )
2012-04-19 05:41:29 +02:00
unset ( $recently_activated [ $key ] );
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 );
} 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 );
}
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 ) ) {
// On the non-network screen, filter out network-only plugins as long as they're not individually activated
2012-09-03 21:42:31 +02:00
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 ) ) {
2014-02-28 21:22:14 +01:00
// On the non-network screen, filter out network activated plugins
2010-10-25 04:57:43 +02:00
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 {
2014-02-28 21:22:14 +01:00
if ( ! $screen -> in_admin ( 'network' ) && isset ( $recently_activated [ $plugin_file ] ) ) {
// On the non-network screen, 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 ;
}
}
if ( $s ) {
$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 ];
if ( $orderby ) {
$orderby = ucfirst ( $orderby );
$order = strtoupper ( $order );
2013-09-05 18:34:09 +02:00
uasort ( $this -> items , array ( $this , '_order_callback' ) );
2010-10-25 04:57:43 +02:00
}
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
/**
* @ staticvar string $term
* @ param array $plugin
* @ return boolean
*/
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 ) {
2010-10-25 04:57:43 +02:00
static $term ;
if ( is_null ( $term ) )
2013-03-01 18:00:25 +01:00
$term = wp_unslash ( $_REQUEST [ 's' ] );
2010-10-25 04:57:43 +02:00
2014-03-11 23:24:15 +01:00
foreach ( $plugin as $value ) {
if ( false !== stripos ( strip_tags ( $value ), $term ) ) {
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 ;
if ( 'DESC' == $order )
return ( $a < $b ) ? 1 : - 1 ;
else
return ( $a < $b ) ? - 1 : 1 ;
}
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 ;
if ( ! empty ( $plugins [ 'all' ] ) )
_e ( 'No plugins found.' );
else
_e ( 'You do not appear to have any plugins available at this time.' );
}
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' ),
);
}
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
}
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
2010-12-18 00:47:40 +01:00
if ( 'search' != $type ) {
$status_links [ $type ] = sprintf ( " <a href='%s' %s>%s</a> " ,
add_query_arg ( 'plugin_status' , $type , 'plugins.php' ),
( $type == $status ) ? ' class="current"' : '' ,
sprintf ( $text , number_format_i18n ( $count ) )
);
}
2010-10-25 04:57:43 +02:00
}
return $status_links ;
}
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
* @ return null
*/
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
* @ return null
*/
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">' ;
2013-03-09 04:52:27 +01:00
if ( ! $this -> screen -> in_admin ( 'network' ) && 'recently_activated' == $status )
2012-11-28 23:20:45 +01:00
submit_button ( __ ( 'Clear List' ), 'button' , 'clear-recent-list' , false );
2011-05-05 07:24:15 +02:00
elseif ( 'top' == $which && 'mustuse' == $status )
echo '<p>' . sprintf ( __ ( 'Files in the <code>%s</code> directory are executed automatically.' ), str_replace ( ABSPATH , '/' , WPMU_PLUGIN_DIR ) ) . '</p>' ;
elseif ( 'top' == $which && 'dropins' == $status )
echo '<p>' . sprintf ( __ ( 'Drop-ins are advanced plugins in the <code>%s</code> directory that replace WordPress functionality when present.' ), str_replace ( ABSPATH , '' , WP_CONTENT_DIR ) ) . '</p>' ;
echo '</div>' ;
2010-10-25 04:57:43 +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 current_action () {
2010-10-25 04:57:43 +02:00
if ( isset ( $_POST [ 'clear-recent-list' ]) )
return 'clear-recent-list' ;
return parent :: current_action ();
}
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
* @ 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
2010-11-13 17:30:20 +01:00
if ( 'mustuse' == $context ) {
$is_active = true ;
} elseif ( 'dropins' == $context ) {
$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 ;
$description = '<p><strong>' . $dropins [ $plugin_file ][ 0 ] . ' <span class="attention">' . __ ( 'Inactive:' ) . '</span></strong> ' . sprintf ( __ ( 'Requires <code>%s</code> in <code>wp-config.php</code>.' ), " define(' " . $dropins [ $plugin_file ][ 1 ] . " ', true); " ) . '</p>' ;
}
if ( $plugin_data [ 'Description' ] )
$description .= '<p>' . $plugin_data [ 'Description' ] . '</p>' ;
} else {
2013-03-09 04:52:27 +01:00
if ( $screen -> in_admin ( 'network' ) )
2012-04-19 05:41:29 +02:00
$is_active = is_plugin_active_for_network ( $plugin_file );
2010-11-13 17:30:20 +01:00
else
$is_active = is_plugin_active ( $plugin_file );
2013-03-09 04:52:27 +01:00
if ( $screen -> in_admin ( 'network' ) ) {
2012-04-19 05:41:29 +02:00
if ( $is_active ) {
2010-11-13 17:30:20 +01:00
if ( current_user_can ( 'manage_network_plugins' ) )
2012-04-19 05:41:29 +02:00
$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 ) . '" title="' . esc_attr__ ( 'Deactivate this plugin' ) . '">' . __ ( 'Network Deactivate' ) . '</a>' ;
2010-10-25 04:57:43 +02:00
} else {
2010-11-13 17:30:20 +01:00
if ( current_user_can ( 'manage_network_plugins' ) )
2012-04-19 05:41:29 +02:00
$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 ) . '" title="' . esc_attr__ ( 'Activate this plugin for all sites in this network' ) . '" class="edit">' . __ ( 'Network Activate' ) . '</a>' ;
2010-12-17 22:53:47 +01:00
if ( current_user_can ( 'delete_plugins' ) && ! is_plugin_active ( $plugin_file ) )
2010-12-21 18:17:58 +01:00
$actions [ 'delete' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=delete-selected&checked[]=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'bulk-plugins' ) . '" title="' . esc_attr__ ( 'Delete this plugin' ) . '" class="delete">' . __ ( 'Delete' ) . '</a>' ;
2010-10-25 04:57:43 +02:00
}
} else {
2010-11-13 17:30:20 +01:00
if ( $is_active ) {
2010-12-21 18:17:58 +01:00
$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 ) . '" title="' . esc_attr__ ( 'Deactivate this plugin' ) . '">' . __ ( 'Deactivate' ) . '</a>' ;
2010-10-25 04:57:43 +02:00
} else {
2010-12-21 18:17:58 +01:00
$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 ) . '" title="' . esc_attr__ ( 'Activate this plugin' ) . '" class="edit">' . __ ( 'Activate' ) . '</a>' ;
2010-11-13 17:30:20 +01:00
if ( ! is_multisite () && current_user_can ( 'delete_plugins' ) )
2010-12-21 18:17:58 +01:00
$actions [ 'delete' ] = '<a href="' . wp_nonce_url ( 'plugins.php?action=delete-selected&checked[]=' . $plugin_file . '&plugin_status=' . $context . '&paged=' . $page . '&s=' . $s , 'bulk-plugins' ) . '" title="' . esc_attr__ ( 'Delete this plugin' ) . '" class="delete">' . __ ( '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
2013-03-09 04:52:27 +01:00
if ( ( ! is_multisite () || $screen -> in_admin ( 'network' ) ) && current_user_can ( 'edit_plugins' ) && is_writable ( WP_PLUGIN_DIR . '/' . $plugin_file ) )
2010-12-21 18:17:58 +01:00
$actions [ 'edit' ] = '<a href="plugin-editor.php?file=' . $plugin_file . '" title="' . esc_attr__ ( 'Open this file in the Plugin Editor' ) . '" class="edit">' . __ ( 'Edit' ) . '</a>' ;
2010-11-13 17:30:20 +01:00
} // end if $context
2013-03-09 04:52:27 +01:00
$prefix = $screen -> in_admin ( 'network' ) ? 'network_admin_' : '' ;
2014-03-02 21:48:14 +01:00
/**
* Filter the action links displayed for each plugin in the Plugins list table .
*
2014-11-30 12:28:24 +01:00
* The dynamic portion of the hook name , `$prefix` , refers to the context the
2014-03-02 21:48:14 +01:00
* action links are displayed in . The 'network_admin_' prefix is used if the
* current screen is the Network plugins list table . The prefix is empty ( '' )
* if the current screen is the site plugins list table .
*
* The default action links for the Network plugins list table include
* 'Network Activate' , 'Network Deactivate' , 'Edit' , and 'Delete' .
*
* 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
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file .
* @ 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' .
*/
2010-12-16 20:22:46 +01:00
$actions = apply_filters ( $prefix . 'plugin_action_links' , array_filter ( $actions ), $plugin_file , $plugin_data , $context );
2014-03-02 21:48:14 +01:00
/**
* Filter the list of action links displayed for a specific plugin .
*
* The first dynamic portion of the hook name , $prefix , refers to the context
* the action links are displayed in . The 'network_admin_' prefix is used if the
* current screen is the Network plugins list table . The prefix is empty ( '' )
* if the current screen is the site plugins list table .
*
* The second 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
*
* @ param array $actions An array of plugin action links .
* @ param string $plugin_file Path to the plugin file .
* @ 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' .
*/
2010-12-16 20:22:46 +01:00
$actions = apply_filters ( $prefix . " 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' ]);
2012-07-25 18:18:14 +02:00
if ( in_array ( $status , array ( 'mustuse' , 'dropins' ) ) ) {
$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' ];
}
$id = sanitize_title ( $plugin_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
2015-03-19 18:48:29 +01:00
$plugin_slug = ( isset ( $plugin_data [ 'slug' ] ) ) ? $plugin_data [ 'slug' ] : '' ;
2015-03-19 06:26:28 +01:00
printf ( " <tr id='%s' class='%s' data-slug='%s'> " ,
$id ,
$class ,
2015-03-19 18:48:29 +01:00
$plugin_slug
2015-03-19 06:26:28 +01:00
);
2010-11-13 17:30:20 +01:00
2010-11-13 17:57:25 +01:00
list ( $columns , $hidden ) = $this -> get_column_info ();
foreach ( $columns as $column_name => $column_display_name ) {
$style = '' ;
if ( in_array ( $column_name , $hidden ) )
$style = ' style="display:none;"' ;
switch ( $column_name ) {
case 'cb' :
echo " <th scope='row' class='check-column'> $checkbox </th> " ;
break ;
case 'name' :
echo " <td class='plugin-title' $style ><strong> $plugin_name </strong> " ;
echo $this -> row_actions ( $actions , true );
echo " </td> " ;
break ;
case 'description' :
echo " <td class='column-description desc' $style >
< 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 :
2010-11-13 18:21:40 +01:00
echo " <td class=' $column_name column- $column_name ' $style > " ;
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 );
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
}
}