public UserViewsData::getViewsData()
Returns views data for the entity type.
Return value
array Views data in the format of hook_views_data().
Overrides EntityViewsData::getViewsData
File
- core/modules/user/src/UserViewsData.php, line 15
Class
- UserViewsData
- Provides the views data for the user entity type.
Namespace
Drupal\user
Code
public function getViewsData() { $data = parent::getViewsData(); $data['users_field_data']['table']['base']['help'] = $this->t('Users who have created accounts on your site.'); $data['users_field_data']['table']['base']['access query tag'] = 'user_access'; $data['users_field_data']['table']['wizard_id'] = 'user'; $data['users_field_data']['uid']['argument']['id'] = 'user_uid'; $data['users_field_data']['uid']['argument'] += array( 'name table' => 'users_field_data', 'name field' => 'name', 'empty field name' => \Drupal::config('user.settings')->get('anonymous'), ); $data['users_field_data']['uid']['filter']['id'] = 'user_name'; $data['users_field_data']['uid']['filter']['title'] = $this->t('Name (autocomplete)'); $data['users_field_data']['uid']['filter']['help'] = $this->t('The user or author name. Uses an autocomplete widget to find a user name, the actual filter uses the resulting user ID.'); $data['users_field_data']['uid']['relationship'] = array( 'title' => $this->t('Content authored'), 'help' => $this->t('Relate content to the user who created it. This relationship will create one record for each content item created by the user.'), 'id' => 'standard', 'base' => 'node_field_data', 'base field' => 'uid', 'field' => 'uid', 'label' => $this->t('nodes'), ); $data['users_field_data']['uid_raw'] = array( 'help' => $this->t('The raw numeric user ID.'), 'real field' => 'uid', 'filter' => array( 'title' => $this->t('The user ID'), 'id' => 'numeric', ), ); $data['users_field_data']['uid_representative'] = array( 'relationship' => array( 'title' => $this->t('Representative node'), 'label' => $this->t('Representative node'), 'help' => $this->t('Obtains a single representative node for each user, according to a chosen sort criterion.'), 'id' => 'groupwise_max', 'relationship field' => 'uid', 'outer field' => 'users_field_data.uid', 'argument table' => 'users_field_data', 'argument field' => 'uid', 'base' => 'node_field_data', 'field' => 'nid', 'relationship' => 'node_field_data:uid' ), ); $data['users']['uid_current'] = array( 'real field' => 'uid', 'title' => $this->t('Current'), 'help' => $this->t('Filter the view to the currently logged in user.'), 'filter' => array( 'id' => 'user_current', 'type' => 'yes-no', ), ); $data['users_field_data']['name']['help'] = $this->t('The user or author name.'); $data['users_field_data']['name']['field']['default_formatter'] = 'user_name'; $data['users_field_data']['name']['filter']['title'] = $this->t('Name (raw)'); $data['users_field_data']['name']['filter']['help'] = $this->t('The user or author name. This filter does not check if the user exists and allows partial matching. Does not use autocomplete.'); // Note that this field implements field level access control. $data['users_field_data']['mail']['help'] = $this->t('Email address for a given user. This field is normally not shown to users, so be cautious when using it.'); $data['users_field_data']['langcode']['help'] = $this->t('Original language of the user information'); $data['users_field_data']['langcode']['help'] = $this->t('Language of the translation of user information'); $data['users_field_data']['preferred_langcode']['title'] = $this->t('Preferred language'); $data['users_field_data']['preferred_langcode']['help'] = $this->t('Preferred language of the user'); $data['users_field_data']['preferred_admin_langcode']['title'] = $this->t('Preferred admin language'); $data['users_field_data']['preferred_admin_langcode']['help'] = $this->t('Preferred administrative language of the user'); $data['users_field_data']['created_fulldate'] = array( 'title' => $this->t('Created date'), 'help' => $this->t('Date in the form of CCYYMMDD.'), 'argument' => array( 'field' => 'created', 'id' => 'date_fulldate', ), ); $data['users_field_data']['created_year_month'] = array( 'title' => $this->t('Created year + month'), 'help' => $this->t('Date in the form of YYYYMM.'), 'argument' => array( 'field' => 'created', 'id' => 'date_year_month', ), ); $data['users_field_data']['created_year'] = array( 'title' => $this->t('Created year'), 'help' => $this->t('Date in the form of YYYY.'), 'argument' => array( 'field' => 'created', 'id' => 'date_year', ), ); $data['users_field_data']['created_month'] = array( 'title' => $this->t('Created month'), 'help' => $this->t('Date in the form of MM (01 - 12).'), 'argument' => array( 'field' => 'created', 'id' => 'date_month', ), ); $data['users_field_data']['created_day'] = array( 'title' => $this->t('Created day'), 'help' => $this->t('Date in the form of DD (01 - 31).'), 'argument' => array( 'field' => 'created', 'id' => 'date_day', ), ); $data['users_field_data']['created_week'] = array( 'title' => $this->t('Created week'), 'help' => $this->t('Date in the form of WW (01 - 53).'), 'argument' => array( 'field' => 'created', 'id' => 'date_week', ), ); $data['users_field_data']['status']['filter']['label'] = $this->t('Active'); $data['users_field_data']['status']['filter']['type'] = 'yes-no'; $data['users_field_data']['changed']['title'] = $this->t('Updated date'); $data['users_field_data']['changed_fulldate'] = array( 'title' => $this->t('Updated date'), 'help' => $this->t('Date in the form of CCYYMMDD.'), 'argument' => array( 'field' => 'changed', 'id' => 'date_fulldate', ), ); $data['users_field_data']['changed_year_month'] = array( 'title' => $this->t('Updated year + month'), 'help' => $this->t('Date in the form of YYYYMM.'), 'argument' => array( 'field' => 'changed', 'id' => 'date_year_month', ), ); $data['users_field_data']['changed_year'] = array( 'title' => $this->t('Updated year'), 'help' => $this->t('Date in the form of YYYY.'), 'argument' => array( 'field' => 'changed', 'id' => 'date_year', ), ); $data['users_field_data']['changed_month'] = array( 'title' => $this->t('Updated month'), 'help' => $this->t('Date in the form of MM (01 - 12).'), 'argument' => array( 'field' => 'changed', 'id' => 'date_month', ), ); $data['users_field_data']['changed_day'] = array( 'title' => $this->t('Updated day'), 'help' => $this->t('Date in the form of DD (01 - 31).'), 'argument' => array( 'field' => 'changed', 'id' => 'date_day', ), ); $data['users_field_data']['changed_week'] = array( 'title' => $this->t('Updated week'), 'help' => $this->t('Date in the form of WW (01 - 53).'), 'argument' => array( 'field' => 'changed', 'id' => 'date_week', ), ); $data['users']['data'] = array( 'title' => $this->t('Data'), 'help' => $this->t('Provides access to the user data service.'), 'real field' => 'uid', 'field' => array( 'id' => 'user_data', ), ); $data['users']['user_bulk_form'] = array( 'title' => $this->t('Bulk update'), 'help' => $this->t('Add a form element that lets you run operations on multiple users.'), 'field' => array( 'id' => 'user_bulk_form', ), ); $data['user__roles']['table']['group'] = $this->t('User'); $data['user__roles']['table']['join'] = array( 'users_field_data' => array( 'left_field' => 'uid', 'field' => 'entity_id', ), ); $data['user__roles']['roles_target_id'] = array( 'title' => $this->t('Roles'), 'help' => $this->t('Roles that a user belongs to.'), 'field' => array( 'id' => 'user_roles', 'no group by' => TRUE, ), 'filter' => array( 'id' => 'user_roles', 'allow empty' => TRUE, ), 'argument' => array( 'id' => 'user__roles_rid', 'name table' => 'role', 'name field' => 'name', 'empty field name' => $this->t('No role'), 'zero is null' => TRUE, 'numeric' => TRUE, ), ); $data['user__roles']['permission'] = array( 'title' => $this->t('Permission'), 'help' => $this->t('The user permissions.'), 'field' => array( 'id' => 'user_permissions', 'no group by' => TRUE, ), 'filter' => array( 'id' => 'user_permissions', 'real field' => 'roles_target_id', ), ); return $data; }
Please login to continue.