2015-09-11 00:55:26 -04:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* WordPress Credits Administration API.
|
|
|
|
*
|
|
|
|
* @package WordPress
|
|
|
|
* @subpackage Administration
|
|
|
|
* @since 4.4.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the contributor credits.
|
|
|
|
*
|
|
|
|
* @since 3.2.0
|
2020-08-03 08:53:08 -04:00
|
|
|
* @since 5.6.0 Added the `$version` and `$locale` parameters.
|
2015-09-11 00:55:26 -04:00
|
|
|
*
|
2020-08-03 08:53:08 -04:00
|
|
|
* @param string $version WordPress version. Defaults to the current version.
|
|
|
|
* @param string $locale WordPress locale. Defaults to the current user's locale.
|
2015-09-11 00:55:26 -04:00
|
|
|
* @return array|false A list of all of the contributors, or false on error.
|
2015-12-12 10:37:28 -05:00
|
|
|
*/
|
2020-08-03 08:53:08 -04:00
|
|
|
function wp_credits( $version = '', $locale = '' ) {
|
|
|
|
if ( ! $version ) {
|
|
|
|
// Include an unmodified $wp_version.
|
|
|
|
require ABSPATH . WPINC . '/version.php';
|
2017-09-27 04:00:49 -04:00
|
|
|
|
2020-08-03 08:53:08 -04:00
|
|
|
$version = $wp_version;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! $locale ) {
|
|
|
|
$locale = get_user_locale();
|
|
|
|
}
|
2015-09-11 00:55:26 -04:00
|
|
|
|
|
|
|
$results = get_site_transient( 'wordpress_credits_' . $locale );
|
|
|
|
|
|
|
|
if ( ! is_array( $results )
|
2020-08-03 08:53:08 -04:00
|
|
|
|| false !== strpos( $version, '-' )
|
Code Modernization: Replace usage of `strpos()` with `str_starts_with()`.
`str_starts_with()` was introduced in PHP 8.0 to perform a case-sensitive check indicating if the string to search in (haystack) begins with the given substring (needle).
WordPress core includes a polyfill for `str_starts_with()` on PHP < 8.0 as of WordPress 5.9.
This commit replaces `0 === strpos( ... )` with `str_starts_with()` in core files, making the code more readable and consistent, as well as improving performance.
While `strpos()` is slightly faster than the polyfill on PHP < 8.0, `str_starts_with()` is noticeably faster on PHP 8.0+, as it is optimized to avoid unnecessarily searching along the whole haystack if it does not find the needle.
Follow-up to [52039], [52040], [52326].
Props spacedmonkey, costdev, sabernhardt, mukesh27, desrosj, jorbin, TobiasBg, ayeshrajans, lgadzhev, SergeyBiryukov.
Fixes #58012.
Built from https://develop.svn.wordpress.org/trunk@55703
git-svn-id: http://core.svn.wordpress.org/trunk@55215 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-05-02 11:45:22 -04:00
|
|
|
|| ( isset( $results['data']['version'] ) && ! str_starts_with( $version, $results['data']['version'] ) )
|
2015-09-11 00:55:26 -04:00
|
|
|
) {
|
2020-08-03 08:53:08 -04:00
|
|
|
$url = "http://api.wordpress.org/core/credits/1.1/?version={$version}&locale={$locale}";
|
|
|
|
$options = array( 'user-agent' => 'WordPress/' . $version . '; ' . home_url( '/' ) );
|
2017-09-27 04:00:49 -04:00
|
|
|
|
|
|
|
if ( wp_http_supports( array( 'ssl' ) ) ) {
|
|
|
|
$url = set_url_scheme( $url, 'https' );
|
|
|
|
}
|
|
|
|
|
|
|
|
$response = wp_remote_get( $url, $options );
|
2015-09-11 00:55:26 -04:00
|
|
|
|
2021-04-06 09:47:02 -04:00
|
|
|
if ( is_wp_error( $response ) || 200 !== wp_remote_retrieve_response_code( $response ) ) {
|
2015-09-11 00:55:26 -04:00
|
|
|
return false;
|
2017-11-30 18:11:00 -05:00
|
|
|
}
|
2015-09-11 00:55:26 -04:00
|
|
|
|
|
|
|
$results = json_decode( wp_remote_retrieve_body( $response ), true );
|
|
|
|
|
2017-11-30 18:11:00 -05:00
|
|
|
if ( ! is_array( $results ) ) {
|
2015-09-11 00:55:26 -04:00
|
|
|
return false;
|
2017-11-30 18:11:00 -05:00
|
|
|
}
|
2015-09-11 00:55:26 -04:00
|
|
|
|
|
|
|
set_site_transient( 'wordpress_credits_' . $locale, $results, DAY_IN_SECONDS );
|
|
|
|
}
|
|
|
|
|
|
|
|
return $results;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the link to a contributor's WordPress.org profile page.
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
* @since 3.2.0
|
|
|
|
*
|
2017-10-02 18:14:46 -04:00
|
|
|
* @param string $display_name The contributor's display name (passed by reference).
|
2015-09-11 00:55:26 -04:00
|
|
|
* @param string $username The contributor's username.
|
|
|
|
* @param string $profiles URL to the contributor's WordPress.org profile page.
|
|
|
|
*/
|
|
|
|
function _wp_credits_add_profile_link( &$display_name, $username, $profiles ) {
|
|
|
|
$display_name = '<a href="' . esc_url( sprintf( $profiles, $username ) ) . '">' . esc_html( $display_name ) . '</a>';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve the link to an external library used in WordPress.
|
|
|
|
*
|
|
|
|
* @access private
|
|
|
|
* @since 3.2.0
|
|
|
|
*
|
2017-10-02 18:14:46 -04:00
|
|
|
* @param string $data External library data (passed by reference).
|
2015-09-11 00:55:26 -04:00
|
|
|
*/
|
|
|
|
function _wp_credits_build_object_link( &$data ) {
|
|
|
|
$data = '<a href="' . esc_url( $data[1] ) . '">' . esc_html( $data[0] ) . '</a>';
|
|
|
|
}
|
2019-11-11 15:45:04 -05:00
|
|
|
|
|
|
|
/**
|
2019-11-16 16:04:01 -05:00
|
|
|
* Displays the title for a given group of contributors.
|
2019-11-11 15:45:04 -05:00
|
|
|
*
|
|
|
|
* @since 5.3.0
|
|
|
|
*
|
|
|
|
* @param array $group_data The current contributor group.
|
|
|
|
*/
|
|
|
|
function wp_credits_section_title( $group_data = array() ) {
|
|
|
|
if ( ! count( $group_data ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $group_data['name'] ) {
|
|
|
|
if ( 'Translators' === $group_data['name'] ) {
|
|
|
|
// Considered a special slug in the API response. (Also, will never be returned for en_US.)
|
|
|
|
$title = _x( 'Translators', 'Translate this to be the equivalent of English Translators in your language for the credits page Translators section' );
|
|
|
|
} elseif ( isset( $group_data['placeholders'] ) ) {
|
|
|
|
// phpcs:ignore WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
|
|
|
|
$title = vsprintf( translate( $group_data['name'] ), $group_data['placeholders'] );
|
|
|
|
} else {
|
|
|
|
// phpcs:ignore WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
|
|
|
|
$title = translate( $group_data['name'] );
|
|
|
|
}
|
|
|
|
|
|
|
|
echo '<h2 class="wp-people-group-title">' . esc_html( $title ) . "</h2>\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2019-11-16 16:04:01 -05:00
|
|
|
* Displays a list of contributors for a given group.
|
2019-11-11 15:45:04 -05:00
|
|
|
*
|
|
|
|
* @since 5.3.0
|
|
|
|
*
|
|
|
|
* @param array $credits The credits groups returned from the API.
|
|
|
|
* @param string $slug The current group to display.
|
|
|
|
*/
|
|
|
|
function wp_credits_section_list( $credits = array(), $slug = '' ) {
|
|
|
|
$group_data = isset( $credits['groups'][ $slug ] ) ? $credits['groups'][ $slug ] : array();
|
|
|
|
$credits_data = $credits['data'];
|
|
|
|
if ( ! count( $group_data ) ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! empty( $group_data['shuffle'] ) ) {
|
|
|
|
shuffle( $group_data['data'] ); // We were going to sort by ability to pronounce "hierarchical," but that wouldn't be fair to Matt.
|
|
|
|
}
|
|
|
|
|
|
|
|
switch ( $group_data['type'] ) {
|
|
|
|
case 'list':
|
|
|
|
array_walk( $group_data['data'], '_wp_credits_add_profile_link', $credits_data['profiles'] );
|
|
|
|
echo '<p class="wp-credits-list">' . wp_sprintf( '%l.', $group_data['data'] ) . "</p>\n\n";
|
|
|
|
break;
|
|
|
|
case 'libraries':
|
|
|
|
array_walk( $group_data['data'], '_wp_credits_build_object_link' );
|
|
|
|
echo '<p class="wp-credits-list">' . wp_sprintf( '%l.', $group_data['data'] ) . "</p>\n\n";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$compact = 'compact' === $group_data['type'];
|
|
|
|
$classes = 'wp-people-group ' . ( $compact ? 'compact' : '' );
|
|
|
|
echo '<ul class="' . $classes . '" id="wp-people-group-' . $slug . '">' . "\n";
|
|
|
|
foreach ( $group_data['data'] as $person_data ) {
|
|
|
|
echo '<li class="wp-person" id="wp-person-' . esc_attr( $person_data[2] ) . '">' . "\n\t";
|
|
|
|
echo '<a href="' . esc_url( sprintf( $credits_data['profiles'], $person_data[2] ) ) . '" class="web">';
|
Help/About: WordPress 5.8 About Page.
This is the start of the WordPress 5.8 about page, introducing new content and a first pass of the new style.
Props chanthaboune, cbringmann, webcommsat, marybaum, melchoyce, shaunandrews, desrosj, ryelle, oglekler, yvettesonneveld, nalininonstopnewsuk, meher, femkreations, alanjacobmathew, courane01, annezazu, matveb, milana_cap, javiarce, ryokuhi, audrasjb.
See #52775.
Built from https://develop.svn.wordpress.org/trunk@51264
git-svn-id: http://core.svn.wordpress.org/trunk@50873 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-06-29 15:06:57 -04:00
|
|
|
$size = $compact ? 80 : 160;
|
2019-11-11 15:45:04 -05:00
|
|
|
$data = get_avatar_data( $person_data[1] . '@md5.gravatar.com', array( 'size' => $size ) );
|
|
|
|
$data2x = get_avatar_data( $person_data[1] . '@md5.gravatar.com', array( 'size' => $size * 2 ) );
|
Help/About: WordPress 5.8 About Page.
This is the start of the WordPress 5.8 about page, introducing new content and a first pass of the new style.
Props chanthaboune, cbringmann, webcommsat, marybaum, melchoyce, shaunandrews, desrosj, ryelle, oglekler, yvettesonneveld, nalininonstopnewsuk, meher, femkreations, alanjacobmathew, courane01, annezazu, matveb, milana_cap, javiarce, ryokuhi, audrasjb.
See #52775.
Built from https://develop.svn.wordpress.org/trunk@51264
git-svn-id: http://core.svn.wordpress.org/trunk@50873 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2021-06-29 15:06:57 -04:00
|
|
|
echo '<span class="wp-person-avatar"><img src="' . esc_url( $data['url'] ) . '" srcset="' . esc_url( $data2x['url'] ) . ' 2x" class="gravatar" alt="" /></span>' . "\n";
|
2019-11-11 15:45:04 -05:00
|
|
|
echo esc_html( $person_data[0] ) . "</a>\n\t";
|
2021-10-19 19:09:00 -04:00
|
|
|
if ( ! $compact && ! empty( $person_data[3] ) ) {
|
2019-11-11 15:45:04 -05:00
|
|
|
// phpcs:ignore WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
|
|
|
|
echo '<span class="title">' . translate( $person_data[3] ) . "</span>\n";
|
|
|
|
}
|
|
|
|
echo "</li>\n";
|
|
|
|
}
|
|
|
|
echo "</ul>\n";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|