You are here

class ApprovedRequestJoinGroupActivityContext in Open Social 10.3.x

Same name and namespace in other branches
  1. 8.9 modules/social_features/social_group/modules/social_group_request/src/Plugin/ActivityContext/ApprovedRequestJoinGroupActivityContext.php \Drupal\social_group_request\Plugin\ActivityContext\ApprovedRequestJoinGroupActivityContext
  2. 10.0.x modules/social_features/social_group/modules/social_group_request/src/Plugin/ActivityContext/ApprovedRequestJoinGroupActivityContext.php \Drupal\social_group_request\Plugin\ActivityContext\ApprovedRequestJoinGroupActivityContext
  3. 10.1.x modules/social_features/social_group/modules/social_group_request/src/Plugin/ActivityContext/ApprovedRequestJoinGroupActivityContext.php \Drupal\social_group_request\Plugin\ActivityContext\ApprovedRequestJoinGroupActivityContext
  4. 10.2.x modules/social_features/social_group/modules/social_group_request/src/Plugin/ActivityContext/ApprovedRequestJoinGroupActivityContext.php \Drupal\social_group_request\Plugin\ActivityContext\ApprovedRequestJoinGroupActivityContext

Provides a 'ApprovedRequestJoinGroupActivityContext' activity context.

Plugin annotation


@ActivityContext(
 id = "approved_request_join_group_activity_context",
 label = @Translation("Approved request to join a group activity context"),
)

Hierarchy

Expanded class hierarchy of ApprovedRequestJoinGroupActivityContext

File

modules/social_features/social_group/modules/social_group_request/src/Plugin/ActivityContext/ApprovedRequestJoinGroupActivityContext.php, line 17

Namespace

Drupal\social_group_request\Plugin\ActivityContext
View source
class ApprovedRequestJoinGroupActivityContext extends ActivityContextBase {

  /**
   * {@inheritdoc}
   */
  public function getRecipients(array $data, $last_uid, $limit) {
    $recipients = [];
    if (!empty($data['related_object'])) {
      $referenced_entity = $this->activityFactory
        ->getActivityRelatedEntity($data);
      $storage = $this->entityTypeManager
        ->getStorage('group_content');

      /** @var \Drupal\group\Entity\GroupContentInterface $group_content */
      $group_content = $storage
        ->load($referenced_entity['target_id']);
      $filters = [
        'entity_id' => $group_content
          ->getEntity()
          ->id(),
        'grequest_status' => GroupMembershipRequest::REQUEST_ACCEPTED,
      ];
      $requests = $storage
        ->loadByGroup($group_content
        ->getGroup(), 'group_membership_request', $filters);
      if (!empty($requests)) {
        $recipients[] = [
          'target_type' => 'user',
          'target_id' => $group_content
            ->getEntity()
            ->id(),
        ];
      }
    }
    return $recipients;
  }

  /**
   * {@inheritdoc}
   */
  public function isValidEntity(EntityInterface $entity) {

    /** @var \Drupal\Core\Entity\EntityInterface $entity */
    return $entity
      ->getEntityTypeId() === 'group_content';
  }

}

Members

Namesort descending Modifiers Type Description Overrides
ActivityContextBase::$activityFactory protected property The activity factory service.
ActivityContextBase::$entityQuery private property The entity query.
ActivityContextBase::$entityTypeManager protected property The entity type manager.
ActivityContextBase::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create 7
ActivityContextBase::getRecipientsFromPost public function Returns recipients from post.
ActivityContextBase::__construct public function ActivityContextBase constructor. Overrides PluginBase::__construct 7
ApprovedRequestJoinGroupActivityContext::getRecipients public function Returns a batched list of recipients for this context. Overrides ActivityContextBase::getRecipients
ApprovedRequestJoinGroupActivityContext::isValidEntity public function Determines if the entity is valid for this context. Overrides ActivityContextBase::isValidEntity
PluginBase::$configuration protected property Configuration information passed into the plugin. 1
PluginBase::$pluginDefinition protected property The plugin implementation definition. 1
PluginBase::$pluginId protected property The plugin_id.
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition 2
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.