View source
<?php
namespace Drupal\social_group\Plugin\Action;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Entity\EntityTypeManagerInterface;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Plugin\PluginFormInterface;
use Drupal\Core\Routing\RouteMatchInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\group\Entity\GroupContentInterface;
use Drupal\views_bulk_operations\Action\ViewsBulkOperationsActionBase;
use Symfony\Component\DependencyInjection\ContainerInterface;
class ChangeGroupMembershipRole extends ViewsBulkOperationsActionBase implements ContainerFactoryPluginInterface, PluginFormInterface {
protected $storage;
protected $routeMatch;
public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityTypeManagerInterface $entity_type_manager, RouteMatchInterface $route_match) {
parent::__construct($configuration, $plugin_id, $plugin_definition);
$this->storage = $entity_type_manager
->getStorage('group');
$this->routeMatch = $route_match;
}
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($configuration, $plugin_id, $plugin_definition, $container
->get('entity_type.manager'), $container
->get('current_route_match'));
}
public function execute($entity = NULL) {
$role = $this->configuration['role'];
$is_member = $this->configuration['is_member'];
$update = TRUE;
$value = [];
$roles =& $entity
->get('group_roles');
if ($roles
->isEmpty() && $is_member) {
$update = FALSE;
}
elseif (!$roles
->isEmpty() && !$is_member) {
$value = $roles
->getValue();
foreach ($value as $item) {
if ($item['target_id'] === $role) {
$update = FALSE;
break;
}
}
}
if ($update) {
if (!$is_member) {
$value[] = [
'target_id' => $role,
];
}
$entity
->set('group_roles', $value)
->save();
}
return $this
->t('Change roles');
}
public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
if ($object instanceof GroupContentInterface && $object
->getContentPlugin()
->getPluginId() === 'group_membership') {
$access = $object
->access('update', $account, TRUE);
}
else {
$access = AccessResult::forbidden();
}
return $return_as_object ? $access : $access
->isAllowed();
}
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$form['#title'] = $this
->formatPlural($this->context['selected_count'], 'Change the role of selected member', 'Change the role of @count selected members');
$id = $this->routeMatch
->getRawParameter('group');
$group_type = $this->storage
->load($id)
->getGroupType();
$roles = $group_type
->getRoles(FALSE);
$id = $group_type
->getMemberRoleId();
$roles[$id] = $group_type
->getMemberRole();
$markup = $this
->formatPlural($this->context['selected_count'], 'Choose which group roles to assign to the member you selected', 'Choose which group roles to assign to the @count members you selected');
$form['description'] = [
'#markup' => $markup,
];
$form_state
->set('member_role', $id);
foreach ($roles as &$role) {
$role = $role
->label();
}
$form['role'] = [
'#type' => 'radios',
'#title' => $this
->t('Group roles'),
'#options' => $roles,
'#default_value' => $id,
];
unset($form['list']);
$form['actions']['submit']['#value'] = $this
->t('Change role');
$form['actions']['submit']['#attributes']['class'] = [
'button button--primary js-form-submit form-submit btn js-form-submit btn-raised btn-primary waves-effect waves-btn waves-light',
];
$form['actions']['cancel']['#attributes']['class'] = [
'button button--danger btn btn-flat waves-effect waves-btn',
];
return $form;
}
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
parent::submitConfigurationForm($form, $form_state);
$this->configuration['is_member'] = $this->configuration['role'] === $form_state
->get('member_role');
}
}