From 9f8d1ab69dcf2c866b7f4885373baa1e51f2ebc0 Mon Sep 17 00:00:00 2001 From: Aaron Jorbin Date: Wed, 21 Feb 2018 23:01:31 +0000 Subject: [PATCH] Community Events Dashboard: Always show a WordCamp if one is coming up WordCamps are celebrations of the local WordPress Community and once a local one is scheduled, people in that community should know it is coming. This adjusts the WordPress Events in the dashboard widgets to always display a WordCamp, even if there are multiple Meetups happening first. Props iandunn, metalandcoffee, warmlaundry, alejandroxlopez, jorbin. Fixes #41112. Built from https://develop.svn.wordpress.org/trunk@42726 git-svn-id: http://core.svn.wordpress.org/trunk@42556 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- .../includes/class-wp-community-events.php | 26 ++++++++++++++++--- wp-includes/version.php | 2 +- 2 files changed, 24 insertions(+), 4 deletions(-) diff --git a/wp-admin/includes/class-wp-community-events.php b/wp-admin/includes/class-wp-community-events.php index 410f9b6237..90ed6f95d5 100644 --- a/wp-admin/includes/class-wp-community-events.php +++ b/wp-admin/includes/class-wp-community-events.php @@ -416,20 +416,33 @@ class WP_Community_Events { } /** - * Discards expired events, and reduces the remaining list. + * Prepares the event list for presentation. + * + * Discards expired events, and makes WordCamps "sticky." Attendees need more + * advanced notice about WordCamps than they do for meetups, so camps should + * appear in the list sooner. If a WordCamp is coming up, the API will "stick" + * it in the response, even if it wouldn't otherwise appear. When that happens, + * the event will be at the end of the list, and will need to be moved into a + * higher position, so that it doesn't get trimmed off. * * @since 4.8.0 + * @since 5.0.0 Stick a WordCamp to the final list. * * @param array $response_body The response body which contains the events. * @return array The response body with events trimmed. */ protected function trim_events( $response_body ) { if ( isset( $response_body['events'] ) ) { + $wordcamps = array(); $current_timestamp = current_time( 'timestamp' ); foreach ( $response_body['events'] as $key => $event ) { - // Skip WordCamps, because they might be multi-day events. - if ( 'meetup' !== $event['type'] ) { + /* + * Skip WordCamps, because they might be multi-day events. + * Save a copy so they can be pinned later. + */ + if ( 'wordcamp' === $event['type'] ) { + $wordcamps[] = $event; continue; } @@ -441,6 +454,13 @@ class WP_Community_Events { } $response_body['events'] = array_slice( $response_body['events'], 0, 3 ); + $trimmed_event_types = array_column( $response_body['events'], 'type' ); + + // Make sure the soonest upcoming WordCamps is pinned in the list. + if ( ! in_array( 'wordcamp', $trimmed_event_types ) && $wordcamps ) { + array_pop( $response_body['events'] ); + array_push( $response_body['events'], $wordcamps[0] ); + } } return $response_body; diff --git a/wp-includes/version.php b/wp-includes/version.php index 3fade09b31..0610c9d99a 100644 --- a/wp-includes/version.php +++ b/wp-includes/version.php @@ -4,7 +4,7 @@ * * @global string $wp_version */ -$wp_version = '5.0-alpha-42725'; +$wp_version = '5.0-alpha-42726'; /** * Holds the WordPress DB revision, increments when changes are made to the WordPress DB schema.