public function EventRequestEnrollmentNotification::build in Open Social 8.9
Same name and namespace in other branches
- 10.3.x modules/social_features/social_event/src/Plugin/Block/EventRequestEnrollmentNotification.php \Drupal\social_event\Plugin\Block\EventRequestEnrollmentNotification::build()
 - 10.0.x modules/social_features/social_event/src/Plugin/Block/EventRequestEnrollmentNotification.php \Drupal\social_event\Plugin\Block\EventRequestEnrollmentNotification::build()
 - 10.1.x modules/social_features/social_event/src/Plugin/Block/EventRequestEnrollmentNotification.php \Drupal\social_event\Plugin\Block\EventRequestEnrollmentNotification::build()
 - 10.2.x modules/social_features/social_event/src/Plugin/Block/EventRequestEnrollmentNotification.php \Drupal\social_event\Plugin\Block\EventRequestEnrollmentNotification::build()
 
Builds and returns the renderable array for this block plugin.
If a block should not be rendered because it has no content, then this method must also ensure to return no content: it must then only return an empty array, or an empty array with #cache set (with cacheability metadata indicating the circumstances for it being empty).
Return value
array A renderable array representing the content of the block.
Overrides BlockPluginInterface::build
See also
\Drupal\block\BlockViewBuilder
File
- modules/
social_features/ social_event/ src/ Plugin/ Block/ EventRequestEnrollmentNotification.php, line 120  
Class
- EventRequestEnrollmentNotification
 - Provides a 'Event requests notification' block.
 
Namespace
Drupal\social_event\Plugin\BlockCode
public function build() : array {
  // No event? Don't bother anymore.
  if (!$this->event instanceof NodeInterface) {
    return [];
  }
  // Don't continue if we don't have the correct enroll method for this event.
  if ((int) $this->event
    ->getFieldValue('field_enroll_method', 'value') !== EventEnrollmentInterface::ENROLL_METHOD_REQUEST) {
    return [];
  }
  // At this point we try to get the amount of pending requests.
  try {
    $requests = $this->entityTypeManager
      ->getStorage('event_enrollment')
      ->getQuery()
      ->condition('field_event.target_id', $this->event
      ->id())
      ->condition('field_request_or_invite_status.value', EventEnrollmentInterface::REQUEST_PENDING)
      ->condition('field_enrollment_status.value', '0')
      ->count()
      ->execute();
    if (!$requests) {
      return [];
    }
    return [
      '#type' => 'html_tag',
      '#tag' => 'div',
      '#value' => $this
        ->t('There @link to enroll in this event.', [
        '@link' => Link::fromTextAndUrl($this->translation
          ->formatPlural($requests, 'is (1) new request', 'are (@count) new requests'), Url::fromRoute('view.event_manage_enrollment_requests.page_manage_enrollment_requests', [
          'node' => $this->event
            ->id(),
        ]))
          ->toString(),
      ]),
      '#attributes' => [
        'class' => [
          'alert',
          'alert-warning',
        ],
      ],
    ];
  } catch (InvalidPluginDefinitionException $e) {
    $this->loggerFactory
      ->get('social_event')
      ->error($e
      ->getMessage());
  } catch (PluginNotFoundException $e) {
    $this->loggerFactory
      ->get('social_event')
      ->error($e
      ->getMessage());
  }
  // Catch all.
  return [];
}