2011-11-02 05:14:14 +01:00
< ? php
2008-09-17 02:40:10 +02:00
/**
* WordPress Plugin Install Administration API
*
* @ package WordPress
* @ subpackage Administration
*/
/**
* Retrieve plugin installer pages from WordPress Plugins API .
*
* It is possible for a plugin to override the Plugin API result with three
* filters . Assume this is for plugins , which can extend on the Plugin Info to
* offer more choices . This is very powerful and must be used with care , when
2011-09-05 21:25:55 +02:00
* overriding the filters .
2008-09-17 02:40:10 +02:00
*
* The first filter , 'plugins_api_args' , is for the args and gives the action as
* the second parameter . The hook for 'plugins_api_args' must ensure that an
* object is returned .
*
* The second filter , 'plugins_api' , is the result that would be returned .
*
2008-10-10 20:21:16 +02:00
* @ since 2.7 . 0
*
2008-09-17 02:40:10 +02:00
* @ param string $action
* @ param array | object $args Optional . Arguments to serialize for the Plugin Info API .
2010-01-17 04:26:50 +01:00
* @ return object plugins_api response object on success , WP_Error on failure .
2008-09-17 02:40:10 +02:00
*/
function plugins_api ( $action , $args = null ) {
2008-08-04 23:17:42 +02:00
2010-01-18 21:34:48 +01:00
if ( is_array ( $args ) )
2008-08-04 23:17:42 +02:00
$args = ( object ) $args ;
2008-11-20 22:22:24 +01:00
if ( ! isset ( $args -> per_page ) )
$args -> per_page = 24 ;
2013-09-20 04:22:10 +02:00
/**
* Override the Plugin Install API arguments .
*
* Please ensure that an object is returned .
*
* @ since 2.7 . 0
*
* @ param object $args Plugin API arguments .
* @ param string $action The type of information being requested from the Plugin Install API .
*/
$args = apply_filters ( 'plugins_api_args' , $args , $action );
/**
* Allows a plugin to override the WordPress . org Plugin Install API entirely .
*
* Please ensure that an object is returned .
*
* @ since 2.7 . 0
*
* @ param bool | object The result object . Default is false .
* @ param string $action The type of information being requested from the Plugin Install API .
* @ param object $args Plugin API arguments .
*/
$res = apply_filters ( 'plugins_api' , false , $action , $args );
2008-08-09 07:36:14 +02:00
2010-01-17 04:26:50 +01:00
if ( false === $res ) {
2013-09-09 09:54:11 +02:00
$url = 'http://api.wordpress.org/plugins/info/1.0/' ;
if ( wp_http_supports ( array ( 'ssl' ) ) )
$url = set_url_scheme ( $url , 'https' );
$request = wp_remote_post ( $url , array (
'timeout' => 15 ,
'body' => array (
'action' => $action ,
'request' => serialize ( $args )
)
) );
2008-10-14 17:56:33 +02:00
if ( is_wp_error ( $request ) ) {
2012-05-09 17:55:59 +02:00
$res = new WP_Error ( 'plugins_api_failed' , __ ( 'An unexpected error occurred. Something may be wrong with WordPress.org or this server’s configuration. If you continue to have problems, please try the <a href="http://wordpress.org/support/">support forums</a>.' ), $request -> get_error_message () );
2008-10-14 17:56:33 +02:00
} else {
2012-01-08 04:48:05 +01:00
$res = maybe_unserialize ( wp_remote_retrieve_body ( $request ) );
if ( ! is_object ( $res ) && ! is_array ( $res ) )
2012-05-09 17:55:59 +02:00
$res = new WP_Error ( 'plugins_api_failed' , __ ( 'An unexpected error occurred. Something may be wrong with WordPress.org or this server’s configuration. If you continue to have problems, please try the <a href="http://wordpress.org/support/">support forums</a>.' ), wp_remote_retrieve_body ( $request ) );
2008-10-14 17:56:33 +02:00
}
2009-06-16 21:36:48 +02:00
} elseif ( ! is_wp_error ( $res ) ) {
$res -> external = true ;
2008-08-04 23:17:42 +02:00
}
2013-09-20 04:22:10 +02:00
/**
* Filter the Plugin Install API response results .
*
* @ since 2.7 . 0
*
* @ param object | WP_Error $res Response object or WP_Error .
* @ param string $action The type of information being requested from the Plugin Install API .
* @ param object $args Plugin API arguments .
*/
return apply_filters ( 'plugins_api_result' , $res , $action , $args );
2008-08-04 23:17:42 +02:00
}
2008-09-17 02:40:10 +02:00
/**
2008-10-10 20:21:16 +02:00
* Retrieve popular WordPress plugin tags .
*
* @ since 2.7 . 0
2008-09-17 02:40:10 +02:00
*
2008-10-10 20:21:16 +02:00
* @ param array $args
* @ return array
2008-09-17 02:40:10 +02:00
*/
2008-08-04 23:17:42 +02:00
function install_popular_tags ( $args = array () ) {
2010-06-19 09:28:27 +02:00
$key = md5 ( serialize ( $args ));
if ( false !== ( $tags = get_site_transient ( 'poptags_' . $key ) ) )
return $tags ;
2008-08-04 23:17:42 +02:00
2008-08-05 19:06:42 +02:00
$tags = plugins_api ( 'hot_tags' , $args );
2008-08-04 23:17:42 +02:00
2008-10-14 17:56:33 +02:00
if ( is_wp_error ( $tags ) )
return $tags ;
2012-09-25 07:26:19 +02:00
set_site_transient ( 'poptags_' . $key , $tags , 3 * HOUR_IN_SECONDS );
2008-08-04 23:17:42 +02:00
return $tags ;
}
2008-10-10 20:21:16 +02:00
2008-10-14 01:39:56 +02:00
function install_dashboard () {
2008-08-04 23:17:42 +02:00
?>
2013-05-22 23:26:36 +02:00
< p >< ? php printf ( __ ( 'Plugins extend and expand the functionality of WordPress. You may automatically install plugins from the <a href="%1$s">WordPress Plugin Directory</a> or upload a plugin in .zip format via <a href="%2$s">this page</a>.' ), 'http://wordpress.org/plugins/' , self_admin_url ( 'plugin-install.php?tab=upload' ) ); ?> </p>
2008-08-09 07:36:14 +02:00
2008-08-04 23:17:42 +02:00
< h4 >< ? php _e ( 'Search' ) ?> </h4>
2012-04-25 21:37:19 +02:00
< ? php install_search_form ( false ); ?>
2008-12-09 19:03:31 +01:00
2008-08-04 23:17:42 +02:00
< h4 >< ? php _e ( 'Popular tags' ) ?> </h4>
2009-03-20 01:14:57 +01:00
< p class = " install-help " >< ? php _e ( 'You may also browse based on the most popular tags in the Plugin Directory:' ) ?> </p>
2008-08-04 23:17:42 +02:00
< ? php
2008-10-10 20:21:16 +02:00
$api_tags = install_popular_tags ();
2008-08-04 23:17:42 +02:00
2009-03-20 01:14:57 +01:00
echo '<p class="popular-tags">' ;
2010-04-25 07:39:39 +02:00
if ( is_wp_error ( $api_tags ) ) {
echo $api_tags -> get_error_message ();
} else {
2011-09-03 16:18:10 +02:00
//Set up the tags in a way which can be interpreted by wp_generate_tag_cloud()
2010-04-25 07:39:39 +02:00
$tags = array ();
foreach ( ( array ) $api_tags as $tag )
$tags [ $tag [ 'name' ] ] = ( object ) array (
2010-10-20 16:16:03 +02:00
'link' => esc_url ( self_admin_url ( 'plugin-install.php?tab=search&type=tag&s=' . urlencode ( $tag [ 'name' ])) ),
2010-04-25 07:39:39 +02:00
'name' => $tag [ 'name' ],
'id' => sanitize_title_with_dashes ( $tag [ 'name' ]),
'count' => $tag [ 'count' ] );
2011-11-02 03:36:18 +01:00
echo wp_generate_tag_cloud ( $tags , array ( 'single_text' => __ ( '%s plugin' ), 'multiple_text' => __ ( '%s plugins' ) ) );
2010-04-25 07:39:39 +02:00
}
2009-03-10 19:31:55 +01:00
echo '</p><br class="clear" />' ;
2008-08-04 23:17:42 +02:00
}
2010-08-11 23:54:51 +02:00
add_action ( 'install_plugins_dashboard' , 'install_dashboard' );
2008-08-04 23:17:42 +02:00
2008-10-18 22:46:30 +02:00
/**
* Display search form for searching plugins .
*
* @ since 2.7 . 0
*/
2012-04-25 21:37:19 +02:00
function install_search_form ( $type_selector = true ) {
2013-03-01 18:00:25 +01:00
$type = isset ( $_REQUEST [ 'type' ]) ? wp_unslash ( $_REQUEST [ 'type' ] ) : 'term' ;
$term = isset ( $_REQUEST [ 's' ]) ? wp_unslash ( $_REQUEST [ 's' ] ) : '' ;
2008-08-04 23:17:42 +02:00
2010-08-11 23:54:51 +02:00
?> <form id="search-plugins" method="get" action="">
< input type = " hidden " name = " tab " value = " search " />
2012-04-25 21:37:19 +02:00
< ? php if ( $type_selector ) : ?>
2008-08-04 23:17:42 +02:00
< select name = " type " id = " typeselector " >
2012-03-30 23:17:22 +02:00
< option value = " term " < ? php selected ( 'term' , $type ) ?> ><?php _e('Keyword'); ?></option>
2009-05-07 12:18:12 +02:00
< option value = " author " < ? php selected ( 'author' , $type ) ?> ><?php _e('Author'); ?></option>
2010-05-14 23:46:25 +02:00
< option value = " tag " < ? php selected ( 'tag' , $type ) ?> ><?php _ex('Tag', 'Plugin Installer'); ?></option>
2008-08-04 23:17:42 +02:00
</ select >
2012-04-25 21:37:19 +02:00
< ? php endif ; ?>
2012-06-26 22:55:46 +02:00
< input type = " search " name = " s " value = " <?php echo esc_attr( $term ) ?> " autofocus = " autofocus " />
2009-05-13 00:40:56 +02:00
< label class = " screen-reader-text " for = " plugin-search-input " >< ? php _e ( 'Search Plugins' ); ?> </label>
2012-09-21 21:34:23 +02:00
< ? php submit_button ( __ ( 'Search Plugins' ), 'button' , 'plugin-search-input' , false ); ?>
2008-08-04 23:17:42 +02:00
</ form >< ? php
}
2009-03-20 14:31:00 +01:00
/**
* Upload from zip
* @ since 2.8 . 0
2009-04-20 20:18:39 +02:00
*
2009-03-20 14:31:00 +01:00
* @ param string $page
*/
function install_plugins_upload ( $page = 1 ) {
?>
2012-11-08 00:54:03 +01:00
< h4 >< ? php _e ( 'Install a plugin in .zip format' ); ?> </h4>
< p class = " install-help " >< ? php _e ( 'If you have a plugin in a .zip format, you may install it by uploading it here.' ); ?> </p>
< form method = " post " enctype = " multipart/form-data " class = " wp-upload-form " action = " <?php echo self_admin_url('update.php?action=upload-plugin'); ?> " >
< ? php wp_nonce_field ( 'plugin-upload' ); ?>
2009-05-13 00:40:56 +02:00
< label class = " screen-reader-text " for = " pluginzip " >< ? php _e ( 'Plugin zip file' ); ?> </label>
2009-05-01 23:52:34 +02:00
< input type = " file " id = " pluginzip " name = " pluginzip " />
2012-11-08 00:54:03 +01:00
< ? php submit_button ( __ ( 'Install Now' ), 'button' , 'install-plugin-submit' , false ); ?>
2009-03-20 14:31:00 +01:00
</ form >
< ? php
}
2010-08-11 23:54:51 +02:00
add_action ( 'install_plugins_upload' , 'install_plugins_upload' , 10 , 1 );
2008-08-04 23:17:42 +02:00
2012-09-27 02:47:01 +02:00
/**
* Show a username form for the favorites page
* @ since 3.5 . 0
*
*/
function install_plugins_favorites_form () {
2013-03-01 18:00:25 +01:00
$user = ! empty ( $_GET [ 'user' ] ) ? wp_unslash ( $_GET [ 'user' ] ) : get_user_option ( 'wporg_favorites' );
2012-09-27 02:47:01 +02:00
?>
< p class = " install-help " >< ? php _e ( 'If you have marked plugins as favorites on WordPress.org, you can browse them here.' ); ?> </p>
< form method = " get " action = " " >
< input type = " hidden " name = " tab " value = " favorites " />
< p >
< label for = " user " >< ? php _e ( 'Your WordPress.org username:' ); ?> </label>
< input type = " search " id = " user " name = " user " value = " <?php echo esc_attr( $user ); ?> " />
< input type = " submit " class = " button " value = " <?php esc_attr_e( 'Get Favorites' ); ?> " />
</ p >
</ form >
< ? php
}
2008-10-10 20:21:16 +02:00
/**
* Display plugin content based on plugin list .
*
* @ since 2.7 . 0
*/
2010-08-11 23:54:51 +02:00
function display_plugins_table () {
2010-08-22 13:22:46 +02:00
global $wp_list_table ;
2008-08-04 23:17:42 +02:00
2012-09-27 02:47:01 +02:00
if ( current_filter () == 'install_plugins_favorites' && empty ( $_GET [ 'user' ] ) && ! get_user_option ( 'wporg_favorites' ) )
return ;
2010-08-22 13:22:46 +02:00
$wp_list_table -> display ();
2008-08-04 23:17:42 +02:00
}
2012-09-27 02:47:01 +02:00
add_action ( 'install_plugins_search' , 'display_plugins_table' );
add_action ( 'install_plugins_featured' , 'display_plugins_table' );
add_action ( 'install_plugins_popular' , 'display_plugins_table' );
add_action ( 'install_plugins_new' , 'display_plugins_table' );
add_action ( 'install_plugins_favorites' , 'display_plugins_table' );
2008-10-10 20:21:16 +02:00
2010-04-02 01:17:53 +02:00
/**
* Determine the status we can perform on a plugin .
*
* @ since 3.0 . 0
*/
function install_plugin_install_status ( $api , $loop = false ) {
2011-09-03 16:18:10 +02:00
// this function is called recursively, $loop prevents further loops.
2010-04-02 01:17:53 +02:00
if ( is_array ( $api ) )
$api = ( object ) $api ;
//Default to a "new" plugin
$status = 'install' ;
$url = false ;
//Check to see if this plugin is known to be installed, and has an update awaiting it.
$update_plugins = get_site_transient ( 'update_plugins' );
2012-04-17 04:43:13 +02:00
if ( isset ( $update_plugins -> response ) ) {
2010-04-02 01:17:53 +02:00
foreach ( ( array ) $update_plugins -> response as $file => $plugin ) {
if ( $plugin -> slug === $api -> slug ) {
$status = 'update_available' ;
$update_file = $file ;
$version = $plugin -> new_version ;
if ( current_user_can ( 'update_plugins' ) )
2010-10-20 16:16:03 +02:00
$url = wp_nonce_url ( self_admin_url ( 'update.php?action=upgrade-plugin&plugin=' . $update_file ), 'upgrade-plugin_' . $update_file );
2010-04-02 01:17:53 +02:00
break ;
}
}
}
if ( 'install' == $status ) {
2011-12-14 00:45:31 +01:00
if ( is_dir ( WP_PLUGIN_DIR . '/' . $api -> slug ) ) {
2010-04-02 01:17:53 +02:00
$installed_plugin = get_plugins ( '/' . $api -> slug );
if ( empty ( $installed_plugin ) ) {
if ( current_user_can ( 'install_plugins' ) )
2010-10-20 16:16:03 +02:00
$url = wp_nonce_url ( self_admin_url ( 'update.php?action=install-plugin&plugin=' . $api -> slug ), 'install-plugin_' . $api -> slug );
2010-04-02 01:17:53 +02:00
} else {
2013-07-17 23:08:05 +02:00
$key = array_keys ( $installed_plugin );
$key = array_shift ( $key ); //Use the first plugin regardless of the name, Could have issues for multiple-plugins in one directory if they share different version numbers
2010-04-02 01:17:53 +02:00
if ( version_compare ( $api -> version , $installed_plugin [ $key ][ 'Version' ], '=' ) ){
$status = 'latest_installed' ;
} elseif ( version_compare ( $api -> version , $installed_plugin [ $key ][ 'Version' ], '<' ) ) {
$status = 'newer_installed' ;
$version = $installed_plugin [ $key ][ 'Version' ];
} else {
//If the above update check failed, Then that probably means that the update checker has out-of-date information, force a refresh
if ( ! $loop ) {
delete_site_transient ( 'update_plugins' );
wp_update_plugins ();
return install_plugin_install_status ( $api , true );
}
}
}
} else {
// "install" & no directory with that slug
if ( current_user_can ( 'install_plugins' ) )
2010-10-20 16:16:03 +02:00
$url = wp_nonce_url ( self_admin_url ( 'update.php?action=install-plugin&plugin=' . $api -> slug ), 'install-plugin_' . $api -> slug );
2010-04-02 01:17:53 +02:00
}
}
2010-05-27 13:04:08 +02:00
if ( isset ( $_GET [ 'from' ]) )
2013-03-01 18:00:25 +01:00
$url .= '&from=' . urlencode ( wp_unslash ( $_GET [ 'from' ] ) );
2010-04-02 01:17:53 +02:00
return compact ( 'status' , 'url' , 'version' );
}
2008-10-10 20:21:16 +02:00
/**
* Display plugin information in dialog box form .
*
* @ since 2.7 . 0
*/
2008-08-04 23:17:42 +02:00
function install_plugin_information () {
global $tab ;
2008-08-09 07:36:14 +02:00
2013-03-01 18:00:25 +01:00
$api = plugins_api ( 'plugin_information' , array ( 'slug' => wp_unslash ( $_REQUEST [ 'plugin' ] ) ));
2008-08-04 23:17:42 +02:00
2008-10-14 17:56:33 +02:00
if ( is_wp_error ( $api ) )
wp_die ( $api );
2012-01-08 10:18:56 +01:00
$plugins_allowedtags = array (
'a' => array ( 'href' => array (), 'title' => array (), 'target' => array () ),
'abbr' => array ( 'title' => array () ), 'acronym' => array ( 'title' => array () ),
'code' => array (), 'pre' => array (), 'em' => array (), 'strong' => array (),
'div' => array (), 'p' => array (), 'ul' => array (), 'ol' => array (), 'li' => array (),
'h1' => array (), 'h2' => array (), 'h3' => array (), 'h4' => array (), 'h5' => array (), 'h6' => array (),
'img' => array ( 'src' => array (), 'class' => array (), 'alt' => array () )
);
2012-01-08 06:39:49 +01:00
$plugins_section_titles = array (
2012-01-08 10:18:56 +01:00
'description' => _x ( 'Description' , 'Plugin installer section title' ),
'installation' => _x ( 'Installation' , 'Plugin installer section title' ),
'faq' => _x ( 'FAQ' , 'Plugin installer section title' ),
'screenshots' => _x ( 'Screenshots' , 'Plugin installer section title' ),
'changelog' => _x ( 'Changelog' , 'Plugin installer section title' ),
'other_notes' => _x ( 'Other Notes' , 'Plugin installer section title' )
);
2012-01-08 06:39:49 +01:00
2008-10-14 17:56:33 +02:00
//Sanitize HTML
foreach ( ( array ) $api -> sections as $section_name => $content )
$api -> sections [ $section_name ] = wp_kses ( $content , $plugins_allowedtags );
2011-08-23 17:56:14 +02:00
foreach ( array ( 'version' , 'author' , 'requires' , 'tested' , 'homepage' , 'downloaded' , 'slug' ) as $key ) {
if ( isset ( $api -> $key ) )
$api -> $key = wp_kses ( $api -> $key , $plugins_allowedtags );
}
2008-10-14 17:56:33 +02:00
2013-09-02 15:54:10 +02:00
$section = isset ( $_REQUEST [ 'section' ] ) ? wp_unslash ( $_REQUEST [ 'section' ] ) : 'description' ; //Default to the Description tab, Do not translate, API returns English.
if ( empty ( $section ) || ! isset ( $api -> sections [ $section ] ) ) {
$section_titles = array_keys ( ( array ) $api -> sections );
$section = array_shift ( $section_titles );
}
2008-08-09 07:36:14 +02:00
2008-12-09 19:03:31 +01:00
iframe_header ( __ ( 'Plugin Install' ) );
2008-08-04 23:17:42 +02:00
echo " <div id=' $tab -header'> \n " ;
echo " <ul id='sidemenu'> \n " ;
foreach ( ( array ) $api -> sections as $section_name => $content ) {
2008-08-09 07:36:14 +02:00
2012-01-08 06:39:49 +01:00
if ( isset ( $plugins_section_titles [ $section_name ] ) )
$title = $plugins_section_titles [ $section_name ];
else
$title = ucwords ( str_replace ( '_' , ' ' , $section_name ) );
2008-08-04 23:17:42 +02:00
$class = ( $section_name == $section ) ? ' class="current"' : '' ;
$href = add_query_arg ( array ( 'tab' => $tab , 'section' => $section_name ) );
2009-05-18 18:00:33 +02:00
$href = esc_url ( $href );
2012-01-08 06:39:49 +01:00
$san_section = esc_attr ( $section_name );
echo " \t <li><a name=' $san_section ' href=' $href ' $class > $title </a></li> \n " ;
2008-08-04 23:17:42 +02:00
}
echo " </ul> \n " ;
echo " </div> \n " ;
?>
< div class = " alignright fyi " >
2010-04-02 01:17:53 +02:00
< ? php if ( ! empty ( $api -> download_link ) && ( current_user_can ( 'install_plugins' ) || current_user_can ( 'update_plugins' ) ) ) : ?>
2008-08-04 23:17:42 +02:00
< p class = " action-button " >
< ? php
2010-04-02 01:17:53 +02:00
$status = install_plugin_install_status ( $api );
switch ( $status [ 'status' ] ) {
case 'install' :
2010-04-02 01:38:37 +02:00
if ( $status [ 'url' ] )
2010-04-02 01:17:53 +02:00
echo '<a href="' . $status [ 'url' ] . '" target="_parent">' . __ ( 'Install Now' ) . '</a>' ;
2008-08-04 23:17:42 +02:00
break ;
2010-04-02 01:17:53 +02:00
case 'update_available' :
2010-04-02 01:38:37 +02:00
if ( $status [ 'url' ] )
2010-04-02 01:17:53 +02:00
echo '<a href="' . $status [ 'url' ] . '" target="_parent">' . __ ( 'Install Update Now' ) . '</a>' ;
2008-08-04 23:17:42 +02:00
break ;
2010-04-02 01:17:53 +02:00
case 'newer_installed' :
echo '<a>' . sprintf ( __ ( 'Newer Version (%s) Installed' ), $status [ 'version' ]) . '</a>' ;
2008-11-19 20:25:53 +01:00
break ;
2010-04-02 01:17:53 +02:00
case 'latest_installed' :
echo '<a>' . __ ( 'Latest Version Installed' ) . '</a>' ;
2008-08-04 23:17:42 +02:00
break ;
2010-04-02 01:17:53 +02:00
}
?>
2008-08-04 23:17:42 +02:00
</ p >
< ? php endif ; ?>
2010-01-21 22:37:43 +01:00
< h2 class = " mainheader " >< ? php /* translators: For Your Information */ _e ( 'FYI' ) ?> </h2>
2008-08-04 23:17:42 +02:00
< ul >
< ? php if ( ! empty ( $api -> version ) ) : ?>
< li >< strong >< ? php _e ( 'Version:' ) ?> </strong> <?php echo $api->version ?></li>
< ? php endif ; if ( ! empty ( $api -> author ) ) : ?>
< li >< strong >< ? php _e ( 'Author:' ) ?> </strong> <?php echo links_add_target($api->author, '_blank') ?></li>
< ? php endif ; if ( ! empty ( $api -> last_updated ) ) : ?>
2008-08-09 07:36:14 +02:00
< li >< strong >< ? php _e ( 'Last Updated:' ) ?> </strong> <span title="<?php echo $api->last_updated ?>"><?php
2008-08-04 23:17:42 +02:00
printf ( __ ( '%s ago' ), human_time_diff ( strtotime ( $api -> last_updated )) ) ?> </span></li>
< ? php endif ; if ( ! empty ( $api -> requires ) ) : ?>
< li >< strong >< ? php _e ( 'Requires WordPress Version:' ) ?> </strong> <?php printf(__('%s or higher'), $api->requires) ?></li>
< ? php endif ; if ( ! empty ( $api -> tested ) ) : ?>
< li >< strong >< ? php _e ( 'Compatible up to:' ) ?> </strong> <?php echo $api->tested ?></li>
< ? php endif ; if ( ! empty ( $api -> downloaded ) ) : ?>
2009-02-20 20:35:16 +01:00
< li >< strong >< ? php _e ( 'Downloaded:' ) ?> </strong> <?php printf(_n('%s time', '%s times', $api->downloaded), number_format_i18n($api->downloaded)) ?></li>
2009-06-16 21:36:48 +02:00
< ? php endif ; if ( ! empty ( $api -> slug ) && empty ( $api -> external ) ) : ?>
2013-05-22 23:01:57 +02:00
< li >< a target = " _blank " href = " http://wordpress.org/plugins/<?php echo $api->slug ?>/ " >< ? php _e ( 'WordPress.org Plugin Page »' ) ?> </a></li>
2008-08-04 23:17:42 +02:00
< ? php endif ; if ( ! empty ( $api -> homepage ) ) : ?>
2011-12-14 18:36:38 +01:00
< li >< a target = " _blank " href = " <?php echo $api->homepage ?> " >< ? php _e ( 'Plugin Homepage »' ) ?> </a></li>
2008-08-04 23:17:42 +02:00
< ? php endif ; ?>
</ ul >
2009-06-16 21:36:48 +02:00
< ? php if ( ! empty ( $api -> rating ) ) : ?>
2008-08-04 23:17:42 +02:00
< h2 >< ? php _e ( 'Average Rating' ) ?> </h2>
2009-02-20 20:35:16 +01:00
< div class = " star-holder " title = " <?php printf(_n('(based on %s rating)', '(based on %s ratings)', $api->num_ratings ), number_format_i18n( $api->num_ratings )); ?> " >
2012-05-02 00:09:55 +02:00
< div class = " star star-rating " style = " width: <?php echo esc_attr( str_replace( ',', '.', $api->rating ) ); ?>px " ></ div >
2008-08-04 23:17:42 +02:00
</ div >
2009-02-20 20:35:16 +01:00
< small >< ? php printf ( _n ( '(based on %s rating)' , '(based on %s ratings)' , $api -> num_ratings ), number_format_i18n ( $api -> num_ratings )); ?> </small>
2009-06-16 21:36:48 +02:00
< ? php endif ; ?>
2008-08-04 23:17:42 +02:00
</ div >
2008-08-05 19:06:42 +02:00
< div id = " section-holder " class = " wrap " >
2008-10-14 01:39:56 +02:00
< ? php
2009-03-10 19:31:55 +01:00
if ( ! empty ( $api -> tested ) && version_compare ( substr ( $GLOBALS [ 'wp_version' ], 0 , strlen ( $api -> tested )), $api -> tested , '>' ) )
2008-10-14 01:39:56 +02:00
echo '<div class="updated"><p>' . __ ( '<strong>Warning:</strong> This plugin has <strong>not been tested</strong> with your current version of WordPress.' ) . '</p></div>' ;
2009-03-10 19:31:55 +01:00
else if ( ! empty ( $api -> requires ) && version_compare ( substr ( $GLOBALS [ 'wp_version' ], 0 , strlen ( $api -> requires )), $api -> requires , '<' ) )
echo '<div class="updated"><p>' . __ ( '<strong>Warning:</strong> This plugin has <strong>not been marked as compatible</strong> with your version of WordPress.' ) . '</p></div>' ;
2008-08-05 19:06:42 +02:00
foreach ( ( array ) $api -> sections as $section_name => $content ) {
2012-01-08 06:39:49 +01:00
if ( isset ( $plugins_section_titles [ $section_name ] ) )
$title = $plugins_section_titles [ $section_name ];
else
$title = ucwords ( str_replace ( '_' , ' ' , $section_name ) );
2008-08-09 07:36:14 +02:00
2013-05-22 23:01:57 +02:00
$content = links_add_base_url ( $content , 'http://wordpress.org/plugins/' . $api -> slug . '/' );
2008-08-05 19:06:42 +02:00
$content = links_add_target ( $content , '_blank' );
2008-08-09 07:36:14 +02:00
2012-01-08 06:39:49 +01:00
$san_section = esc_attr ( $section_name );
2008-08-09 07:36:14 +02:00
2008-08-05 19:06:42 +02:00
$display = ( $section_name == $section ) ? 'block' : 'none' ;
2008-08-09 07:36:14 +02:00
2012-01-08 06:39:49 +01:00
echo " \t <div id='section- { $san_section } ' class='section' style='display: { $display } ;'> \n " ;
2008-08-05 19:06:42 +02:00
echo " \t \t <h2 class='long-header'> $title </h2> " ;
echo $content ;
echo " \t </div> \n " ;
}
2008-08-04 23:17:42 +02:00
echo " </div> \n " ;
2008-08-05 19:06:42 +02:00
2008-10-14 01:39:56 +02:00
iframe_footer ();
2008-08-04 23:17:42 +02:00
exit ;
}
2010-08-11 23:54:51 +02:00
add_action ( 'install_plugins_pre_plugin-information' , 'install_plugin_information' );