Index: wp-admin/css/colors-classic.css
===================================================================
--- wp-admin/css/colors-classic.css	(revision 8027)
+++ wp-admin/css/colors-classic.css	(working copy)
@@ -415,11 +415,11 @@
 	background-color: #fff;
 }
 
-#plugins .active {
+.plugins .active {
 	background-color: #BBEEBB;
 }
 
-#plugins .togl {
+.plugins .togl {
 	border-right-color: #ccc;
 }
 
@@ -427,7 +427,7 @@
 	background-color: #ffffe0;
 }
 
-#plugins tr {
+.plugins tr {
 	background-color: #fff;
 }
 
Index: wp-admin/css/colors-fresh.css
===================================================================
--- wp-admin/css/colors-fresh.css	(revision 8027)
+++ wp-admin/css/colors-fresh.css	(working copy)
@@ -384,11 +384,11 @@
 	background-color: #fff;
 }
 
-#plugins .active {
+.plugins .active {
 	background-color: #e7f7d3;
 }
 
-#plugins .togl {
+.plugins .togl {
 	border-right-color: #ccc;
 }
 
@@ -396,7 +396,7 @@
 	background-color: #ffffe0;
 }
 
-#plugins tr {
+.plugins tr {
 	background-color: #fff;
 }
 
Index: wp-admin/includes/plugin.php
===================================================================
--- wp-admin/includes/plugin.php	(revision 8027)
+++ wp-admin/includes/plugin.php	(working copy)
@@ -132,37 +132,97 @@
 	update_option('active_plugins', $current);
 }
 
-function deactivate_all_plugins() {
-	$current = get_option('active_plugins');
-	if ( empty($current) )
-		return;
+//Replaces reactivate_all_plugins() / deactivate_all_plugins()  = 'deactivated_plugins' is now useless
+function activate_plugins($plugins, $redirect = '') {
+	if ( !is_array($plugins) )
+		$plugins = array($plugins);
 
-	deactivate_plugins($current);
+	$errors = array();
+	foreach ( (array) $plugins as $plugin ) {
+		if ( !empty($redirect) )
+			$redirect = add_query_arg('plugin', $plugin, $redirect);
+		$result = activate_plugin($plugin, $redirect);
+		if ( is_wp_error($result) )
+			$errors[$plugin] = $result;
+	}
 
-	update_option('deactivated_plugins', $current);
+	if ( !empty($errors) )
+		return new WP_Error('plugins_invalid', __('One of the plugins is invalid.'), $errors);
+
+	return true;
 }
 
-function reactivate_all_plugins($redirect = '') {
-	$plugins = get_option('deactivated_plugins');
+function delete_plugins($plugins, $redirect = '' ) {
+	global $wp_filesystem;
 
-	if ( empty($plugins) )
+	if( empty($plugins) )
+		return false;
+
+	$checked = array();
+	foreach( $plugins as $plugin )
+		$checked[] = 'checked[]=' . $plugin;
+
+	ob_start();
+	$url = wp_nonce_url('plugins.php?action=delete-selected&' . implode('&', $checked), 'mass-manage-plugins');
+	if ( false === ($credentials = request_filesystem_credentials($url)) ) {
+		$data = ob_get_contents();
+		ob_end_clean();
+		if( ! empty($data) ){
+			include_once( ABSPATH . 'wp-admin/admin-header.php');
+			echo $data;
+			include( ABSPATH . 'wp-admin/admin-footer.php');
+			exit;
+		}
 		return;
+	}
 
-	if ( !empty($redirect) )
-		wp_redirect(add_query_arg('_error_nonce', wp_create_nonce('plugin-activation-error_' . $plugin), $redirect));
+	if ( ! WP_Filesystem($credentials) ) {
+		request_filesystem_credentials($url, '', true); //Failed to connect, Error and request again
+		$data = ob_get_contents();
+		ob_end_clean();
+		if( ! empty($data) ){
+			include_once( ABSPATH . 'wp-admin/admin-header.php');
+			echo $data;
+			include( ABSPATH . 'wp-admin/admin-footer.php');
+			exit;
+		}
+		return;
+	}
 
-	$errors = array();
-	foreach ( (array) $plugins as $plugin ) {
-		$result = activate_plugin($plugin);
-		if ( is_wp_error($result) )
-			$errors[$plugin] = $result;
+	if ( $wp_filesystem->errors->get_error_code() ) {
+		return $wp_filesystem->errors;
 	}
 
-	delete_option('deactivated_plugins');
+	if ( ! is_object($wp_filesystem) )
+		return new WP_Error('fs_unavailable', __('Could not access filesystem.'));
 
-	if ( !empty($errors) )
-		return new WP_Error('plugins_invalid', __('One of the plugins is invalid.'), $errors);
+	if ( $wp_filesystem->errors->get_error_code() )
+		return new WP_Error('fs_error', __('Filesystem error'), $wp_filesystem->errors);
 
+	//Get the base plugin folder
+	$plugins_dir = $wp_filesystem->wp_plugins_dir();
+	if ( empty($plugins_dir) )
+		return new WP_Error('fs_no_plugins_dir', __('Unable to locate WordPress Plugin directory.'));
+	
+	$plugins_dir = trailingslashit( $plugins_dir );
+
+	$errors = array();
+
+	foreach( $plugins as $plugin_file ) {
+		$this_plugin_dir = trailingslashit( dirname($plugins_dir . $plugin_file) );
+		// If plugin is in its own directory, recursively delete the directory.
+		if ( strpos($plugin_file, '/') && $this_plugin_dir != $plugins_dir ) //base check on if plugin includes directory seperator AND that its not the root plugin folder
+			$deleted = $wp_filesystem->delete($this_plugin_dir, true);
+		else
+			$deleted = $wp_filesystem->delete($plugins_dir . $plugin_file);
+	
+		if ( ! $deleted )
+			$errors[] = $plugin_file;
+	}
+	
+	if( ! empty($errors) )
+		return new WP_Error('could_not_remove_plugin', sprintf(__('Could not fully remove the plugin(s) %s'), implode(', ', $errors)) );
+	
 	return true;
 }
 
Index: wp-admin/includes/update.php
===================================================================
--- wp-admin/includes/update.php	(revision 8027)
+++ wp-admin/includes/update.php	(working copy)
@@ -118,25 +118,24 @@
 }
 add_action( 'load-plugins.php', 'wp_update_plugins' );
 
-function wp_plugin_update_row( $file ) {
-	global $plugin_data;
+function wp_plugin_update_row( $file, $plugin_data ) {
 	$current = get_option( 'update_plugins' );
 	if ( !isset( $current->response[ $file ] ) )
 		return false;
 
 	$r = $current->response[ $file ];
 
-	echo "<tr><td colspan='5' class='plugin-update'>";
+	echo '<tr><td colspan="5" class="plugin-update">';
 	if ( !current_user_can('edit_plugins') )
 		printf( __('There is a new version of %1$s available. <a href="%2$s">Download version %3$s here</a>.'), $plugin_data['Name'], $r->url, $r->new_version);
 	else if ( empty($r->package) )
 		printf( __('There is a new version of %1$s available. <a href="%2$s">Download version %3$s here</a> <em>automatic upgrade unavailable for this plugin</em>.'), $plugin_data['Name'], $r->url, $r->new_version);
 	else
-		printf( __('There is a new version of %1$s available. <a href="%2$s">Download version %3$s here</a> or <a href="%4$s">upgrade automatically</a>.'), $plugin_data['Name'], $r->url, $r->new_version, wp_nonce_url("update.php?action=upgrade-plugin&amp;plugin=$file", 'upgrade-plugin_' . $file) );
+		printf( __('There is a new version of %1$s available. <a href="%2$s">Download version %3$s here</a> or <a href="%4$s">upgrade automatically</a>.'), $plugin_data['Name'], $r->url, $r->new_version, wp_nonce_url('update.php?action=upgrade-plugin&amp;plugin=' . $file, 'upgrade-plugin_' . $file) );
 	
-	echo "</td></tr>";
+	echo '</td></tr>';
 }
-add_action( 'after_plugin_row', 'wp_plugin_update_row' );
+add_action( 'after_plugin_row', 'wp_plugin_update_row', 10, 2 );
 
 function wp_update_plugin($plugin, $feedback = '') {
 	global $wp_filesystem;
Index: wp-admin/menu-header.php
===================================================================
--- wp-admin/menu-header.php	(revision 8027)
+++ wp-admin/menu-header.php	(working copy)
@@ -2,6 +2,8 @@
 $self = preg_replace('|^.*/wp-admin/|i', '', $_SERVER['PHP_SELF']);
 $self = preg_replace('|^.*/plugins/|i', '', $self);
 
+global $menu, $submenu, $parent_file; //For when admin-header is included from within a function.
+
 get_admin_page_parent();
 
 // We're going to do this loop three times
Index: wp-admin/plugins.php
===================================================================
--- wp-admin/plugins.php	(revision 8027)
+++ wp-admin/plugins.php	(working copy)
@@ -1,41 +1,103 @@
 <?php
 require_once('admin.php');
 
-if ( isset($_GET['action']) ) {
-	if ( isset($_GET['plugin']) )
-		$plugin = trim($_GET['plugin']);
+$action = '';
+foreach( array('activate-selected', 'deactivate-selected', 'delete-selected') as $action_key ) {
+	if( isset($_POST[$action_key]) ) {
+		$action = $action_key;
+		break;
+	}
+}
 
-	if ( 'activate' == $_GET['action'] ) {
-		check_admin_referer('activate-plugin_' . $_GET['plugin']);
-		$result = activate_plugin($_GET['plugin'], 'plugins.php?error=true&plugin=' . $plugin);
-		if ( is_wp_error( $result ) )
-			wp_die( $result->get_error_message() );
-		wp_redirect('plugins.php?activate=true'); // overrides the ?error=true one above
-	} elseif ( 'error_scrape' == $_GET['action'] ) {
-		check_admin_referer('plugin-activation-error_' . $plugin);
-		$valid = validate_plugin($plugin);
-		if ( is_wp_error($valid) )
-			wp_die($valid);
-		error_reporting( E_ALL ^ E_NOTICE );
-		@ini_set('display_errors', true); //Ensure that Fatal errors are displayed.
-		include(WP_PLUGIN_DIR . '/' . $plugin);
-	} elseif ( 'deactivate' == $_GET['action'] ) {
-		check_admin_referer('deactivate-plugin_' . $_GET['plugin']);
-		deactivate_plugins($_GET['plugin']);
-		wp_redirect('plugins.php?deactivate=true');
-	} elseif ( 'deactivate-all' == $_GET['action'] ) {
-		check_admin_referer('deactivate-all');
-		deactivate_all_plugins();
-		wp_redirect('plugins.php?deactivate-all=true');
-	} elseif ('reactivate-all' == $_GET['action']) {
-		check_admin_referer('reactivate-all');
-		reactivate_all_plugins('plugins.php?errors=true');
-		wp_redirect('plugins.php?reactivate-all=true'); // overrides the ?error=true one above
+if( isset($_GET['action']) )
+	$action = $_GET['action'];
+
+$plugin = $_REQUEST['plugin'];
+
+if( !empty($action) ) {
+	switch( $action ) {
+		case 'activate':
+			check_admin_referer('activate-plugin_' . $plugin);
+			$result = activate_plugin($plugin, 'plugins.php?error=true&plugin=' . $plugin);
+			if ( is_wp_error( $result ) )
+				wp_die( $result->get_error_message() );
+			$recent = (array)get_option('recently_activated');
+			if( isset($recent[ $plugin ]) ){
+				unset($recent[ $plugin ]);
+				update_option('recently_activated', $recent);
+			}
+			wp_redirect('plugins.php?activate=true'); // overrides the ?error=true one above
+			exit;
+			break;
+		case 'activate-selected':
+			check_admin_referer('mass-manage-plugins');
+			activate_plugins($_POST['checked'], 'plugins.php?error=true');
+
+			$recent = (array)get_option('recently_activated');
+			foreach( (array)$_POST['checked'] as $plugin => $time) {
+				if( isset($recent[ $plugin ]) )
+					unset($recent[ $plugin ]);
+			}
+			if( $recent != get_option('recently_activated') ) //If array changed, update it.
+				update_option('recently_activated', $recent);
+
+			wp_redirect('plugins.php?activate-multi=true');
+			exit;
+			break;
+		case 'error_scrape':
+			check_admin_referer('plugin-activation-error_' . $plugin);
+			$valid = validate_plugin($plugin);
+			if ( is_wp_error($valid) )
+				wp_die($valid);
+			error_reporting( E_ALL ^ E_NOTICE );
+			@ini_set('display_errors', true); //Ensure that Fatal errors are displayed.
+			include(WP_PLUGIN_DIR . '/' . $plugin);
+			exit;
+			break;
+		case 'deactivate':
+			check_admin_referer('deactivate-plugin_' . $plugin);
+			deactivate_plugins($plugin);
+			update_option('recently_activated', array($plugin => time()) + (array)get_option('recently_activated'));
+			wp_redirect('plugins.php?deactivate=true');
+			exit;
+			break;
+		case 'deactivate-selected':
+			check_admin_referer('mass-manage-plugins');
+			deactivate_plugins($_POST['checked']);
+			$deactivated = array();
+			foreach( (array)$_POST['checked'] as $plugin )
+				$deactivated[ $plugin ] = time();
+			update_option('recently_activated', $deactivated + (array)get_option('recently_activated'));
+			wp_redirect('plugins.php?deactivate-multi=true');
+			exit;
+			break;
+		case 'delete-selected':
+			check_admin_referer('mass-manage-plugins');
+			$plugins = $_REQUEST['checked'];
+			include(ABSPATH . 'wp-admin/update.php');
+
+			$title = __('Delete Plugin');
+			$parent_file = 'plugins.php';
+
+			$delete_result = delete_plugins($plugins);
+			
+			//HACK TIME!
+			// Proper way needed, perhaps get_plugins() to convert to wp_cache_get() any reason why it hasnt allready?
+			// This clears the cached plugin list
+			global $wp_plugins;
+			$wp_plugins = null;
+			
+			
+				
+			//TODO: Implement!.. STAT!
+			break;
+		default:
+			var_dump("Unknown Action $action");
 	}
-
-	exit;
 }
 
+wp_enqueue_script('admin-forms');
+
 $title = __('Manage Plugins');
 require_once('admin-header.php');
 
@@ -46,23 +108,26 @@
 <?php if ( isset($_GET['error']) ) : ?>
 	<div id="message" class="updated fade"><p><?php _e('Plugin could not be activated because it triggered a <strong>fatal error</strong>.') ?></p>
 	<?php
-		$plugin = trim($_GET['plugin']);
 		if ( wp_verify_nonce($_GET['_error_nonce'], 'plugin-activation-error_' . $plugin) ) { ?>
-	<iframe style="border:0" width="100%" height="70px" src="<?php bloginfo('wpurl'); ?>/wp-admin/plugins.php?action=error_scrape&amp;plugin=<?php echo attribute_escape($plugin); ?>&amp;_wpnonce=<?php echo attribute_escape($_GET['_error_nonce']); ?>"></iframe>
+	<iframe style="border:0" width="100%" height="70px" src="<?php echo admin_url('plugins.php?action=error_scrape&amp;plugin=' . attribute_escape($plugin) . '&amp;_wpnonce=' . attribute_escape($_GET['_error_nonce'])); ?>"></iframe>
 	<?php
 		}
 	?>
 	</div>
-<?php elseif ( isset($_GET['errors']) ) : ?>
-	<div id="message" class="updated fade"><p><?php _e('Some plugins could not be reactivated because they triggered a <strong>fatal error</strong>.') ?></p></div>
+<?php elseif ( 'delete-selected' == $action ) :
+		if ( is_wp_error($delete_result) ) : ?>
+		<div id="message" class="updated fade"><p><?php printf( __('Plugin could not be deleted due to an error: %s'), $delete_result->get_error_message() ); ?></p></div>
+		<?php else : ?>
+		<div id="message" class="updated fade"><p><?php _e('The selected plugins have been <strong>deleted</strong>.'); ?></p></div>
+		<?php endif; ?>
 <?php elseif ( isset($_GET['activate']) ) : ?>
 	<div id="message" class="updated fade"><p><?php _e('Plugin <strong>activated</strong>.') ?></p></div>
+<?php elseif (isset($_GET['activate-multi'])) : ?>
+	<div id="message" class="updated fade"><p><?php _e('Selected plugins <strong>activated</strong>.'); ?></p></div>
 <?php elseif ( isset($_GET['deactivate']) ) : ?>
 	<div id="message" class="updated fade"><p><?php _e('Plugin <strong>deactivated</strong>.') ?></p></div>
-<?php elseif (isset($_GET['deactivate-all'])) : ?>
-	<div id="message" class="updated fade"><p><?php _e('All plugins <strong>deactivated</strong>.'); ?></p></div>
-<?php elseif (isset($_GET['reactivate-all'])) : ?>
-	<div id="message" class="updated fade"><p><?php _e('Plugins <strong>reactivated</strong>.'); ?></p></div>
+<?php elseif (isset($_GET['deactivate-multi'])) : ?>
+	<div id="message" class="updated fade"><p><?php _e('Selected plugins <strong>deactivated</strong>.'); ?></p></div>
 <?php endif; ?>
 
 <div class="wrap">
@@ -70,104 +135,147 @@
 <p><?php _e('Plugins extend and expand the functionality of WordPress. Once a plugin is installed, you may activate it or deactivate it here.'); ?></p>
 <?php
 
-$plugins = get_plugins();
+$active_plugins = array();
+$available_plugins = array();
+$recent_plugins = array();
+$recently_activated = (array)get_option('recently_activated');
 
-if (empty($plugins)) {
-	echo '<p>';
-	_e("Couldn&#8217;t open plugins directory or there are no plugins available."); // TODO: make more helpful
-	echo '</p>';
-} else {
-?>
+//Clean out any plugins which were deactivated over a week ago.
+foreach( $recently_activated as $key => $time )
+	if( $time + (7*24*60*60) < time() ) //1 week
+		unset($recently_activated[ $key ]);
+if( $recently_activated != get_option('recently_activated') ) //If array changed, update it.
+	update_option('recently_activated', $recently_activated);
 
-<div class="tablenav">
-	<div class="alignleft">
-	<?php
-	$active = get_option('active_plugins');
-	$inactive = get_option('deactivated_plugins');
-	if ( !empty($active) ) {
-	?>
-	<a class="button-secondary delete" href="<?php echo wp_nonce_url('plugins.php?action=deactivate-all', 'deactivate-all'); ?>"><?php _e('Deactivate All Plugins'); ?></a>
-	<?php
-	} elseif ( empty($active) && !empty($inactive) ) {
-	?>
-	<a class="button-secondary delete" href="<?php echo wp_nonce_url('plugins.php?action=reactivate-all', 'reactivate-all'); ?>"><?php _e('Reactivate Plugins'); ?></a>
-	<?php
-	} // endif active/inactive plugin check
-	?>
-	</div>
-	<br class="clear" />
-</div>
+$all_plugins = get_plugins();
 
-<br class="clear" />
+$plugins_allowedtags = array('a' => array('href' => array(),'title' => array()),'abbr' => array('title' => array()),'acronym' => array('title' => array()),'code' => array(),'em' => array(),'strong' => array());
 
-<table class="widefat">
+foreach( (array)$all_plugins as $plugin_file => $plugin_data) {
+
+	// Sanitize all displayed data
+	$plugin_data['Title']       = wp_kses($plugin_data['Title'], $plugins_allowedtags);
+	$plugin_data['Version']     = wp_kses($plugin_data['Version'], $plugins_allowedtags);
+	$plugin_data['Description'] = wp_kses($plugin_data['Description'], $plugins_allowedtags);
+	$plugin_data['Author']      = wp_kses($plugin_data['Author'], $plugins_allowedtags);
+	if( ! empty($plugin_data['Author']) )
+		$plugin_data['Description'] .= ' <cite>' . sprintf( __('By %s'), $plugin_data['Author'] ) . '.</cite>';
+
+	if ( is_plugin_active($plugin_file) ) {
+		$active_plugins[ $plugin_file ] = $plugin_data;
+	} else {
+		if ( isset( $recently_activated[ $plugin_file ] ) ) //Was the plugin recently activated?
+			$recent_plugins[ $plugin_file ] = $plugin_data;
+		else
+			$available_plugins[ $plugin_file ] = $plugin_data;
+	}
+}
+
+?>
+
+<?php
+function print_plugins_table($plugins, $context = '') {
+?>
+<table class="widefat" id="<?php echo $context ?>-plugins-table">
 	<thead>
 	<tr>
-		<th><?php _e('Plugin'); ?></th>
-		<th class="num"><?php _e('Version'); ?></th>
-		<th><?php _e('Description'); ?></th>
-		<th class="status"><?php _e('Status') ?></th>
-		<th class="action-links"><?php _e('Action'); ?></th>
+		<th scope="col" class="check-column"><input type="checkbox" /></th>
+		<th scope="col"><?php _e('Plugin'); ?></th>
+		<th scope="col" class="num"><?php _e('Version'); ?></th>
+		<th scope="col"><?php _e('Description'); ?></th>
+		<th scope="col" class="action-links"><?php _e('Action'); ?></th>
 	</tr>
 	</thead>
-	<tbody id="plugins">
+	<tbody class="plugins">
 <?php
-	foreach($plugins as $plugin_file => $plugin_data) {
+
+	if( empty($plugins) ) {
+		echo '<tr>
+			<td colspan="6">' . __('No plugins to show') . '</td>
+		</tr>';
+	}
+	foreach( (array)$plugins as $plugin_file => $plugin_data) {
 		$action_links = array();
-		
-		$style = '';
 
-		if ( is_plugin_active($plugin_file) ) {
-			$action_links[] = "<a href='" . wp_nonce_url("plugins.php?action=deactivate&amp;plugin=$plugin_file", 'deactivate-plugin_' . $plugin_file) . "' title='".__('Deactivate this plugin')."' class='delete'>".__('Deactivate')."</a>";
-			$style = 'active';
-		} else {
-			$action_links[] = "<a href='" . wp_nonce_url("plugins.php?action=activate&amp;plugin=$plugin_file", 'activate-plugin_' . $plugin_file) . "' title='".__('Activate this plugin')."' class='edit'>".__('Activate')."</a>";
-		}
+		if( 'active' == $context )
+			$action_links[] = '<a href="' . wp_nonce_url('plugins.php?action=deactivate&amp;plugin=' . $plugin_file, 'deactivate-plugin_' . $plugin_file) . '" title="' . __('Deactivate this plugin') . '" class="delete">' . __('Deactivate') . '</a>';
+		else //Available or Recently deactivated
+			$action_links[] = '<a href="' . wp_nonce_url('plugins.php?action=activate&amp;plugin=' . $plugin_file, 'activate-plugin_' . $plugin_file) . '" title="' . __('Activate this plugin') . '" class="edit">' . __('Activate') . '</a>';
+
 		if ( current_user_can('edit_plugins') && is_writable(WP_PLUGIN_DIR . '/' . $plugin_file) )
-			$action_links[] = "<a href='plugin-editor.php?file=$plugin_file' title='".__('Open this file in the Plugin Editor')."' class='edit'>".__('Edit')."</a>";
+			$action_links[] = '<a href="plugin-editor.php?file=' . $plugin_file . '" title="' . __('Open this file in the Plugin Editor') . '" class="edit">' . __('Edit') . '</a>';
 
-		$plugins_allowedtags = array('a' => array('href' => array(),'title' => array()),'abbr' => array('title' => array()),'acronym' => array('title' => array()),'code' => array(),'em' => array(),'strong' => array());
+		$action_links = apply_filters('plugin_action_links', $action_links, $plugin_file, $plugin_data, $context);
 
-		// Sanitize all displayed data
-		$plugin_data['Title']       = wp_kses($plugin_data['Title'], $plugins_allowedtags);
-		$plugin_data['Version']     = wp_kses($plugin_data['Version'], $plugins_allowedtags);
-		$plugin_data['Description'] = wp_kses($plugin_data['Description'], $plugins_allowedtags);
-		$plugin_data['Author']      = wp_kses($plugin_data['Author'], $plugins_allowedtags);
-		$author = ( empty($plugin_data['Author']) ) ? '' :  ' <cite>' . sprintf( __('By %s'), $plugin_data['Author'] ) . '.</cite>';
-
-		if ( $style != '' )
-			$style = ' class="' . $style . '"';
-
-		$action_links = apply_filters('plugin_action_links', $action_links, $plugin_file, $plugin_info);
-
 		echo "
-	<tr$style>
+	<tr class='$context'>
+		<th scope='row' class='check-column'><input type='checkbox' name='checked[]' value='" . attribute_escape($plugin_file) . "' /></th>
 		<td class='name'>{$plugin_data['Title']}</td>
 		<td class='vers'>{$plugin_data['Version']}</td>
-		<td class='desc'><p>{$plugin_data['Description']}$author</p></td>
-		<td class='status'>";
-		if ( is_plugin_active($plugin_file) )
-			echo  __('<span class="active">Active</span>');
-		else
-			_e('<span class="inactive">Inactive</span>');
-		echo "</td>
-		<td class='togl action-links'>$toggle";  
+		<td class='desc'><p>{$plugin_data['Description']}</p></td>
+		<td class='togl action-links'>";  
 		if ( !empty($action_links) )
 			echo implode(' | ', $action_links);
-		echo "</td> 
-	</tr>";
-	do_action( 'after_plugin_row', $plugin_file );
+		echo '</td> 
+	</tr>';
+		do_action( 'after_plugin_row', $plugin_file, $plugin_data, $context );
 	}
 ?>
 	</tbody>
 </table>
-
-<?php
-}
+<?php 
+} //End print_plugins_table()
 ?>
 
+<h3 id="currently-active"><?php _e('Currently Active Plugins') ?></h3>
+<form method="post" action="<?php echo admin_url('plugins.php') ?>">
+<?php wp_nonce_field('mass-manage-plugins') ?>
+
+<div class="tablenav">
+	<div class="alignleft">
+		<input type="submit" name="deactivate-selected" value="<?php _e('Deactivate Selected') ?>" class="button-secondary" />
+	</div>
+</div>
+<br class="clear" />
+<?php print_plugins_table($active_plugins, 'active') ?>
+</form>
+
 <p><?php printf(__('If something goes wrong with a plugin and you can&#8217;t use WordPress, delete or rename that file in the <code>%s</code> directory and it will be automatically deactivated.'), WP_PLUGIN_DIR); ?></p>
 
+<?php if ( ! empty($recent_plugins) ) : ?>
+<h3 id="recent-plugins"><?php _e('Recently Active Plugins') ?></h3>
+<form method="post" action="<?php echo admin_url('plugins.php') ?>">
+<?php wp_nonce_field('mass-manage-plugins') ?>
+
+<div class="tablenav">
+	<div class="alignleft">
+		<input type="submit" name="activate-selected" value="<?php _e('Activate Selected') ?>" class="button-secondary" />
+<?php if( current_user_can('edit_plugins') ) : ?>
+		<input type="submit" name="delete-selected" value="<?php _e('Delete Selected') ?>" class="button-secondary" />
+<?php endif; ?>
+	</div>
+</div>
+<br class="clear" />
+<?php print_plugins_table($recent_plugins, 'recent') ?>
+</form>
+<?php endif; ?>
+
+<h3 id="available-plugins"><?php _e('Available Plugins') ?></h3>
+<form method="post" action="<?php echo admin_url('plugins.php') ?>">
+<?php wp_nonce_field('mass-manage-plugins') ?>
+
+<div class="tablenav">
+	<div class="alignleft">
+		<input type="submit" name="activate-selected" value="<?php _e('Activate Selected') ?>" class="button-secondary" />
+<?php if( current_user_can('edit_plugins') ) : ?>
+		<input type="submit" name="delete-selected" value="<?php _e('Delete Selected') ?>" class="button-secondary" />
+<?php endif; ?>
+	</div>
+</div>
+<br class="clear" />
+<?php print_plugins_table($available_plugins, 'available') ?>
+</form>
+
 <h2><?php _e('Get More Plugins'); ?></h2>
 <p><?php _e('You can find additional plugins for your site in the <a href="http://wordpress.org/extend/plugins/">WordPress plugin directory</a>.'); ?></p>
 <p><?php printf(__('To install a plugin you generally just need to upload the plugin file into your <code>%s</code> directory. Once a plugin is uploaded, you may activate it here.'), WP_PLUGIN_DIR); ?></p>
Index: wp-admin/wp-admin.css
===================================================================
--- wp-admin/wp-admin.css	(revision 8027)
+++ wp-admin/wp-admin.css	(working copy)
@@ -1,13 +1,13 @@
-#plugins .name {
+.plugins .name {
 	font-weight: bold;
 }
 
-#plugins p {
+.plugins p {
 	margin: 0 4px;
 	padding: 0;
 }
 
-#plugins .togl {
+.plugins .togl {
 	width: 150px;
 	border-right-width: 1px;
 	border-right-style: solid;