mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-25 17:51:27 +01:00
fd1f45a7cf
The plugin details modal can be invoked from several screens. There's now a new `.open-plugin-details-modal` CSS class to be used in combination with the `.thickbox` CSS class that adds everything needed for accessibility. - Adds an ARIA role `dialog` and an `aria-label` attribute to the modal - Adds a `title` attribute to the iframe inside the modal - Constrains tabbing within the modal - Restores focus back in a proper place when closing the modal Also, improves a bit the native Thickbox implementation: it should probably be replaced with some more modern tool but at least keyboard focus should be moved inside the modal. Fixes #33305. Built from https://develop.svn.wordpress.org/trunk@36964 git-svn-id: http://core.svn.wordpress.org/trunk@36932 1a063a9b-81f0-0310-95a4-ce76da25c4cd
232 lines
13 KiB
PHP
232 lines
13 KiB
PHP
<?php
|
|
/**
|
|
* About This Version administration panel.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
/** WordPress Administration Bootstrap */
|
|
require_once( dirname( __FILE__ ) . '/admin.php' );
|
|
|
|
wp_enqueue_style( 'wp-mediaelement' );
|
|
wp_enqueue_script( 'wp-mediaelement' );
|
|
wp_localize_script( 'mediaelement', '_wpmejsSettings', array(
|
|
'pluginPath' => includes_url( 'js/mediaelement/', 'relative' ),
|
|
'pauseOtherPlayers' => ''
|
|
) );
|
|
|
|
if ( current_user_can( 'install_plugins' ) ) {
|
|
add_thickbox();
|
|
wp_enqueue_script( 'plugin-install' );
|
|
}
|
|
|
|
$video_url = 'https://videopress.com/embed/J44FHXvg?hd=true';
|
|
$locale = str_replace( '_', '-', get_locale() );
|
|
list( $locale ) = explode( '-', $locale );
|
|
if ( 'en' !== $locale ) {
|
|
$video_url = add_query_arg( 'defaultLangCode', $locale, $video_url );
|
|
}
|
|
|
|
wp_oembed_add_host_js();
|
|
|
|
$title = __( 'About' );
|
|
|
|
list( $display_version ) = explode( '-', $wp_version );
|
|
|
|
include( ABSPATH . 'wp-admin/admin-header.php' );
|
|
?>
|
|
<div class="wrap about-wrap">
|
|
<h1><?php printf( __( 'Welcome to WordPress %s' ), $display_version ); ?></h1>
|
|
|
|
<div class="about-text"><?php printf( __( 'Thank you for updating! WordPress %s makes your site more connected and responsive.' ), $display_version ); ?></div>
|
|
<div class="wp-badge"><?php printf( __( 'Version %s' ), $display_version ); ?></div>
|
|
|
|
<h2 class="nav-tab-wrapper wp-clearfix">
|
|
<a href="about.php" class="nav-tab nav-tab-active"><?php _e( 'What’s New' ); ?></a>
|
|
<a href="credits.php" class="nav-tab"><?php _e( 'Credits' ); ?></a>
|
|
<a href="freedoms.php" class="nav-tab"><?php _e( 'Freedoms' ); ?></a>
|
|
</h2>
|
|
|
|
<div class="headline-feature feature-video">
|
|
<iframe width="1050" height="591" src="<?php echo esc_url( $video_url ); ?>" frameborder="0" allowfullscreen></iframe>
|
|
<script src="https://videopress.com/videopress-iframe.js"></script>
|
|
</div>
|
|
|
|
<hr>
|
|
|
|
<div class="headline-feature feature-section one-col">
|
|
<h2><?php _e( 'Twenty Sixteen' ); ?></h2>
|
|
<div class="media-container">
|
|
<img src="https://s.w.org/images/core/4.4/twenty-sixteen-white-fullsize-2x.png" alt="" srcset="https://s.w.org/images/core/4.4/twenty-sixteen-white-smartphone-1x.png 268w, https://s.w.org/images/core/4.4/twenty-sixteen-white-smartphone-2x.png 536w, https://s.w.org/images/core/4.4/twenty-sixteen-white-tablet-1x.png 558w, https://s.w.org/images/core/4.4/twenty-sixteen-white-desktop-1x.png 840w, https://s.w.org/images/core/4.4/twenty-sixteen-white-fullsize-1x.png 1086w, https://s.w.org/images/core/4.4/twenty-sixteen-white-tablet-2x.png 1116w, https://s.w.org/images/core/4.4/twenty-sixteen-white-desktop-2x.png 1680w, https://s.w.org/images/core/4.4/twenty-sixteen-white-fullsize-2x.png 2172w" sizes="(max-width: 500px) calc((100vw - 40px) * .8), (max-width: 782px) calc((100vw - 70px) * .8), (max-width: 960px) calc((100vw - 116px) * .8), (max-width: 1290px) calc((100vw - 240px) * .8), 840px" />
|
|
</div>
|
|
<div class="two-col">
|
|
<div class="col">
|
|
<h3><?php _e( 'Introducing Twenty Sixteen' ); ?></h3>
|
|
<p><?php _e( 'Our newest default theme, Twenty Sixteen, is a modern take on a classic blog design.' ); ?></p>
|
|
<p><?php _e( 'Twenty Sixteen was built to look great on any device. A fluid grid design, flexible header, fun color schemes, and more, will make your content shine.' ); ?></p>
|
|
<div class="horizontal-image">
|
|
<div class="content">
|
|
<img class="feature-image horizontal-screen" src="https://s.w.org/images/core/4.4/twenty-sixteen-dark-fullsize-2x.png" alt="" srcset="https://s.w.org/images/core/4.4/twenty-sixteen-dark-smartphone-1x.png 268w, https://s.w.org/images/core/4.4/twenty-sixteen-dark-smartphone-2x.png 535w, https://s.w.org/images/core/4.4/twenty-sixteen-dark-desktop-1x.png 558w, https://s.w.org/images/core/4.4/twenty-sixteen-dark-fullsize-1x.png 783w, https://s.w.org/images/core/4.4/twenty-sixteen-dark-desktop-2x.png 1116w, https://s.w.org/images/core/4.4/twenty-sixteen-dark-fullsize-2x.png 1566w" sizes="(max-width: 500px) calc((100vw - 40px) * .8), (max-width: 782px) calc((100vw - 70px) * .8), (max-width: 960px) calc((100vw - 116px) * .5216), (max-width: 1290px) calc((100vw - 240px) * .5216), 548px" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col feature-image">
|
|
<img class="vertical-screen" src="https://s.w.org/images/core/4.4/twenty-sixteen-red-fullsize-2x.png" alt="" srcset="https://s.w.org/images/core/4.4/twenty-sixteen-red-smartphone-1x.png 107w, https://s.w.org/images/core/4.4/twenty-sixteen-red-smartphone-2x.png 214w, https://s.w.org/images/core/4.4/twenty-sixteen-red-desktop-1x.png 252w, https://s.w.org/images/core/4.4/twenty-sixteen-red-fullsize-1x.png 410w, https://s.w.org/images/core/4.4/twenty-sixteen-red-desktop-2x.png 504w, https://s.w.org/images/core/4.4/twenty-sixteen-red-fullsize-2x.png 820w" sizes="(max-width: 500px) calc((100vw - 40px) * .32), (max-width: 782px) calc((100vw - 70px) * .32), (max-width: 960px) calc((100vw - 116px) * .24), (max-width: 1290px) calc((100vw - 240px) * .24), 252px" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<hr />
|
|
|
|
<div class="feature-section two-col">
|
|
<div class="col">
|
|
<div class="media-container">
|
|
<img src="https://s.w.org/images/core/4.4/responsive-devices-fullsize-2x.png" alt="" srcset="https://s.w.org/images/core/4.4/responsive-devices-smartphone-1x.png 335w, https://s.w.org/images/core/4.4/responsive-devices-desktop-1x.png 500w, https://s.w.org/images/core/4.4/responsive-devices-smartphone-2x.png 670w, https://s.w.org/images/core/4.4/responsive-devices-tablet-1x.png 698w, https://s.w.org/images/core/4.4/responsive-devices-desktop-2x.png 1000w, https://s.w.org/images/core/4.4/responsive-devices-fullsize-1x.png 1200w, https://s.w.org/images/core/4.4/responsive-devices-tablet-2x.png 1396w, https://s.w.org/images/core/4.4/responsive-devices-fullsize-2x.png 2400w" sizes="(max-width: 500px) calc(100vw - 40px), (max-width: 782px) calc(100vw - 70px), (max-width: 960px) calc((100vw - 116px) * .476), (max-width: 1290px) calc((100vw - 240px) * .476), 500px" />
|
|
</div>
|
|
</div>
|
|
<div class="col">
|
|
<h3><?php _e( 'Responsive images' ); ?></h3>
|
|
<p><?php _e( 'WordPress now takes a smarter approach to displaying appropriate image sizes on any device, ensuring a perfect fit every time. You don’t need to do anything to your theme, it just works.' ); ?></p>
|
|
</div>
|
|
</div>
|
|
|
|
<hr />
|
|
|
|
<div class="feature-section two-col">
|
|
<div class="col">
|
|
<div class="embed-container">
|
|
<blockquote data-secret="OcUe7B6Edh" class="wp-embedded-content"><a href="https://wordpress.org/news/2015/12/clifford/">WordPress 4.4 “Clifford”</a></blockquote><iframe class="wp-embedded-content" sandbox="allow-scripts" security="restricted" style="display:none;" src="https://wordpress.org/news/2015/12/clifford/embed/#?secret=OcUe7B6Edh" data-secret="OcUe7B6Edh" width="600" height="338" title="<?php esc_attr_e( 'Embedded WordPress Post' ); ?>" frameborder="0" marginwidth="0" marginheight="0" scrolling="no"></iframe>
|
|
</div>
|
|
</div>
|
|
<div class="col">
|
|
<h3><?php _e( 'Embed your WordPress content' ); ?></h3>
|
|
<p><?php _e( 'Now you can embed your posts on other sites, even other WordPress sites. Simply drop a post URL into the editor and see an instant embed preview, complete with the title, excerpt, and featured image if you’ve set one. We’ll even include your site icon and links for comments and sharing.' ); ?></p>
|
|
</div>
|
|
</div>
|
|
|
|
<hr />
|
|
|
|
<div class="feature-section two-col">
|
|
<div class="col">
|
|
<div class="embed-container embed-reverbnation">
|
|
<iframe width="640" height="150" scrolling="no" frameborder="no" src="https://www.reverbnation.com/widget_code/html_widget/artist_607?widget_id=55&pwc[song_ids]=3731874&pwc[size]=small"></iframe>
|
|
</div>
|
|
</div>
|
|
<div class="col">
|
|
<h3><?php _e( 'Even more embed providers' ); ?></h3>
|
|
<p><?php _e( 'In addition to post embeds, WordPress 4.4 also adds support for five new oEmbed providers: Cloudup, Reddit Comments, ReverbNation, Speaker Deck, and VideoPress.' ); ?></p>
|
|
</div>
|
|
</div>
|
|
|
|
<hr />
|
|
|
|
<div class="changelog">
|
|
<h3><?php _e( 'Under the Hood' ); ?></h3>
|
|
|
|
<div class="feature-section under-the-hood one-col">
|
|
<div class="col">
|
|
<h4><?php _e( 'REST API infrastructure' ); ?></h4>
|
|
<div class="two-col-text">
|
|
<p><?php _e( 'Infrastructure for the REST API has been integrated into core, marking a new era in developing with WordPress. The REST API serves to provide developers with a path forward for building and extending RESTful APIs on top of WordPress.' ); ?></p>
|
|
<p><?php
|
|
if ( current_user_can( 'install_plugins' ) ) {
|
|
$url_args = array(
|
|
'tab' => 'plugin-information',
|
|
'plugin' => 'rest-api',
|
|
'TB_iframe' => true,
|
|
'width' => 600,
|
|
'height' => 550
|
|
);
|
|
|
|
$plugin_link = '<a href="' . esc_url( add_query_arg( $url_args, network_admin_url( 'plugin-install.php' ) ) ) . '" class="thickbox open-plugin-details-modal">WordPress REST API</a>';
|
|
} else {
|
|
$plugin_link = '<a href="https://wordpress.org/plugins/rest-api">WordPress REST API</a>';
|
|
}
|
|
|
|
/* translators: WordPress REST API plugin link */
|
|
printf( __( 'Infrastructure is the first part of a multi-stage rollout for the REST API. Inclusion of core endpoints is targeted for an upcoming release. To get a sneak peek of the core endpoints, and for more information on extending the REST API, check out the official %s plugin.' ), $plugin_link );
|
|
?></p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="feature-section under-the-hood three-col">
|
|
<div class="col">
|
|
<h4><?php _e( 'Term meta' ); ?></h4>
|
|
<p><?php
|
|
/* translators: 1: add_term_meta() docs link, 2: get_term_meta() docs link, 3: update_term_meta() docs link */
|
|
printf( __( 'Terms now support metadata, just like posts. See %1$s, %2$s, and %3$s for more information.' ),
|
|
'<a href="https://developer.wordpress.org/reference/functions/add_term_meta"><code>add_term_meta()</code></a>',
|
|
'<a href="https://developer.wordpress.org/reference/functions/get_term_meta"><code>get_term_meta()</code></a>',
|
|
'<a href="https://developer.wordpress.org/reference/functions/update_term_meta"><code>update_term_meta()</code></a>'
|
|
);
|
|
?></p>
|
|
</div>
|
|
<div class="col">
|
|
<h4><?php _e( 'Comment query improvements' ); ?></h4>
|
|
<p><?php
|
|
/* translators: WP_Comment_Query class name */
|
|
printf( __( 'Comment queries now have cache handling to improve performance. New arguments in %s make crafting robust comment queries simpler.' ), '<code>WP_Comment_Query</code>' );
|
|
?></p>
|
|
</div>
|
|
<div class="col">
|
|
<h4><?php _e( 'Term, comment, and network objects' ); ?></h4>
|
|
<p><?php
|
|
/* translators: 1: WP_Term class name, WP_Comment class name, WP_Network class name */
|
|
printf( __( 'New %1$s, %2$s, and %3$s objects make interacting with terms, comments, and networks more predictable and intuitive in code.' ),
|
|
'<code>WP_Term</code>',
|
|
'<code>WP_Comment</code>',
|
|
'<code>WP_Network</code>'
|
|
);
|
|
?></p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="return-to-dashboard">
|
|
<?php if ( current_user_can( 'update_core' ) && isset( $_GET['updated'] ) ) : ?>
|
|
<a href="<?php echo esc_url( self_admin_url( 'update-core.php' ) ); ?>">
|
|
<?php is_multisite() ? _e( 'Return to Updates' ) : _e( 'Return to Dashboard → Updates' ); ?>
|
|
</a> |
|
|
<?php endif; ?>
|
|
<a href="<?php echo esc_url( self_admin_url() ); ?>"><?php is_blog_admin() ? _e( 'Go to Dashboard → Home' ) : _e( 'Go to Dashboard' ); ?></a>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
<?php
|
|
|
|
include( ABSPATH . 'wp-admin/admin-footer.php' );
|
|
|
|
// These are strings we may use to describe maintenance/security releases, where we aim for no new strings.
|
|
return;
|
|
|
|
__( 'Maintenance Release' );
|
|
__( 'Maintenance Releases' );
|
|
|
|
__( 'Security Release' );
|
|
__( 'Security Releases' );
|
|
|
|
__( 'Maintenance and Security Release' );
|
|
__( 'Maintenance and Security Releases' );
|
|
|
|
/* translators: %s: WordPress version number */
|
|
__( '<strong>Version %s</strong> addressed one security issue.' );
|
|
/* translators: %s: WordPress version number */
|
|
__( '<strong>Version %s</strong> addressed some security issues.' );
|
|
|
|
/* translators: 1: WordPress version number, 2: plural number of bugs. */
|
|
_n_noop( '<strong>Version %1$s</strong> addressed %2$s bug.',
|
|
'<strong>Version %1$s</strong> addressed %2$s bugs.' );
|
|
|
|
/* translators: 1: WordPress version number, 2: plural number of bugs. Singular security issue. */
|
|
_n_noop( '<strong>Version %1$s</strong> addressed a security issue and fixed %2$s bug.',
|
|
'<strong>Version %1$s</strong> addressed a security issue and fixed %2$s bugs.' );
|
|
|
|
/* translators: 1: WordPress version number, 2: plural number of bugs. More than one security issue. */
|
|
_n_noop( '<strong>Version %1$s</strong> addressed some security issues and fixed %2$s bug.',
|
|
'<strong>Version %1$s</strong> addressed some security issues and fixed %2$s bugs.' );
|
|
|
|
/* translators: %s: Codex URL */
|
|
__( 'For more information, see <a href="%s">the release notes</a>.' );
|