metatag_extended_perms.module in Metatag 8
Primary hook implementations for metatag_extended_perms.
File
metatag_extended_perms/metatag_extended_perms.moduleView source
<?php
/**
 * @file
 * Primary hook implementations for metatag_extended_perms.
 */
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Render\Element;
use Drupal\metatag\Plugin\Field\FieldWidget\MetatagFirehose;
/**
 * Implements hook_field_widget_form_alter().
 */
function metatag_extended_perms_field_widget_form_alter(&$element, FormStateInterface $form_state, $context) {
  if ($context['widget'] instanceof MetatagFirehose) {
    $group_manager = \Drupal::getContainer()
      ->get('plugin.manager.metatag.group');
    // Prevent access to the element until at least one permission is granted.
    $element['#access'] = FALSE;
    foreach (Element::children($element) as $group_id) {
      $group = $group_manager
        ->getDefinition($group_id, FALSE);
      if ($group === NULL) {
        continue;
      }
      // By default restrict access to group and regain access when user has
      // access to at least one tag in group; this prevents displaying empty
      // groups.
      $element[$group_id]['#access'] = FALSE;
      // Check through each meta tag field on the field widget.
      foreach (Element::children($element[$group_id]) as $tag_id) {
        // Check tag permission.
        $element[$group_id][$tag_id]['#access'] = \Drupal::currentUser()
          ->hasPermission('access metatag ' . $group_id . '__' . $tag_id);
        // Make the parent and group accessible if user has access to the tag.
        if ($element[$group_id][$tag_id]['#access']) {
          $element[$group_id]['#access'] = TRUE;
          $element['#access'] = TRUE;
        }
      }
    }
  }
}Functions
| Name   | Description | 
|---|---|
| metatag_extended_perms_field_widget_form_alter | Implements hook_field_widget_form_alter(). | 
