You are here

class UserData in Drupal 10

Same name in this branch
  1. 10 core/modules/user/src/UserData.php \Drupal\user\UserData
  2. 10 core/modules/user/src/Plugin/views/field/UserData.php \Drupal\user\Plugin\views\field\UserData
  3. 10 core/modules/user/src/Plugin/migrate/destination/UserData.php \Drupal\user\Plugin\migrate\destination\UserData
Same name and namespace in other branches
  1. 8 core/modules/user/src/Plugin/views/field/UserData.php \Drupal\user\Plugin\views\field\UserData
  2. 9 core/modules/user/src/Plugin/views/field/UserData.php \Drupal\user\Plugin\views\field\UserData

Provides access to the user data service.

Plugin annotation

@ViewsField("user_data");

Hierarchy

  • class \Drupal\user\Plugin\views\field\UserData extends \Drupal\views\Plugin\views\field\FieldPluginBase

Expanded class hierarchy of UserData

See also

\Drupal\user\UserDataInterface

File

core/modules/user/src/Plugin/views/field/UserData.php, line 21

Namespace

Drupal\user\Plugin\views\field
View source
class UserData extends FieldPluginBase {

  /**
   * Provides the user data service object.
   *
   * @var \Drupal\user\UserDataInterface
   */
  protected $userData;

  /**
   * The module handler.
   *
   * @var \Drupal\Core\Extension\ModuleHandlerInterface
   */
  protected $moduleHandler;

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    return new static($configuration, $plugin_id, $plugin_definition, $container
      ->get('user.data'), $container
      ->get('module_handler'));
  }

  /**
   * Constructs a UserData object.
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, UserDataInterface $user_data, ModuleHandlerInterface $module_handler) {
    parent::__construct($configuration, $plugin_id, $plugin_definition);
    $this->userData = $user_data;
    $this->moduleHandler = $module_handler;
  }

  /**
   * {@inheritdoc}
   */
  protected function defineOptions() {
    $options = parent::defineOptions();
    $options['data_module'] = [
      'default' => '',
    ];
    $options['data_name'] = [
      'default' => '',
    ];
    return $options;
  }

  /**
   * {@inheritdoc}
   */
  public function buildOptionsForm(&$form, FormStateInterface $form_state) {
    parent::buildOptionsForm($form, $form_state);
    $modules = $this->moduleHandler
      ->getModuleList();
    $names = [];
    foreach (array_keys($modules) as $name) {
      $names[$name] = $this->moduleHandler
        ->getName($name);
    }
    $form['data_module'] = [
      '#title' => $this
        ->t('Module name'),
      '#type' => 'select',
      '#description' => $this
        ->t('The module which sets this user data.'),
      '#default_value' => $this->options['data_module'],
      '#options' => $names,
    ];
    $form['data_name'] = [
      '#title' => $this
        ->t('Name'),
      '#type' => 'textfield',
      '#description' => $this
        ->t('The name of the data key.'),
      '#default_value' => $this->options['data_name'],
    ];
  }

  /**
   * {@inheritdoc}
   */
  public function render(ResultRow $values) {
    $uid = $this
      ->getValue($values);
    $data = $this->userData
      ->get($this->options['data_module'], $uid, $this->options['data_name']);

    // Don't sanitize if no value was found.
    if (isset($data)) {
      return $this
        ->sanitizeValue($data);
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
UserData::$moduleHandler protected property The module handler.
UserData::$userData protected property Provides the user data service object.
UserData::buildOptionsForm public function
UserData::create public static function
UserData::defineOptions protected function
UserData::render public function
UserData::__construct public function Constructs a UserData object.