[ Index ]

PHP Cross Reference of BuddyPress

title

Body

[close]

/src/bp-members/classes/ -> class-bp-members-ms-list-table.php (source)

   1  <?php
   2  /**
   3   * BuddyPress Members List Table for Multisite.
   4   *
   5   * @package BuddyPress
   6   * @subpackage MembersAdminClasses
   7   * @since 2.3.0
   8   */
   9  
  10  // Exit if accessed directly.
  11  defined( 'ABSPATH' ) || exit;
  12  
  13  /**
  14   * List table class for signups network admin page.
  15   *
  16   * @since 2.0.0
  17   */
  18  class BP_Members_MS_List_Table extends WP_MS_Users_List_Table {
  19  
  20      /**
  21       * Signup counts.
  22       *
  23       * @since 2.0.0
  24       *
  25       * @var int
  26       */
  27      public $signup_counts = 0;
  28  
  29      /**
  30       * Signup profile fields.
  31       *
  32       * @since 10.0.0
  33       *
  34       * @var array
  35       */
  36      public $signup_field_labels = array();
  37  
  38      /**
  39       * Constructor.
  40       *
  41       * @since 2.0.0
  42       */
  43  	public function __construct() {
  44          // Define singular and plural labels, as well as whether we support AJAX.
  45          parent::__construct( array(
  46              'ajax'     => false,
  47              'plural'   => 'signups',
  48              'singular' => 'signup',
  49              'screen'   => get_current_screen()->id,
  50          ) );
  51      }
  52  
  53      /**
  54       * Set up items for display in the list table.
  55       *
  56       * Handles filtering of data, sorting, pagination, and any other data
  57       * manipulation required prior to rendering.
  58       *
  59       * @since 2.0.0
  60       */
  61  	public function prepare_items() {
  62          global $usersearch, $mode;
  63  
  64          $usersearch       = isset( $_REQUEST['s'] ) ? $_REQUEST['s'] : '';
  65          $signups_per_page = $this->get_items_per_page( str_replace( '-', '_', "{$this->screen->id}_per_page" ) );
  66          $paged            = $this->get_pagenum();
  67  
  68          $args = array(
  69              'offset'     => ( $paged - 1 ) * $signups_per_page,
  70              'number'     => $signups_per_page,
  71              'usersearch' => $usersearch,
  72              'orderby'    => 'signup_id',
  73              'order'      => 'DESC'
  74          );
  75  
  76          if ( isset( $_REQUEST['orderby'] ) ) {
  77              $args['orderby'] = $_REQUEST['orderby'];
  78          }
  79  
  80          if ( isset( $_REQUEST['order'] ) ) {
  81              $args['order'] = $_REQUEST['order'];
  82          }
  83  
  84          $mode    = empty( $_REQUEST['mode'] ) ? 'list' : $_REQUEST['mode'];
  85          $signups = BP_Signup::get( $args );
  86  
  87          $this->items         = $signups['signups'];
  88          $this->signup_counts = $signups['total'];
  89  
  90          $this->set_pagination_args( array(
  91              'total_items' => $this->signup_counts,
  92              'per_page'    => $signups_per_page,
  93          ) );
  94      }
  95  
  96      /**
  97       * Display the users screen views
  98       *
  99       * @since 2.5.0
 100       *
 101       * @global string $role The name of role the users screens is filtered by
 102       */
 103  	public function views() {
 104          global $role;
 105  
 106          // Used to reset the role.
 107          $reset_role = $role;
 108  
 109          // Temporarly set the role to registered.
 110          $role = 'registered';
 111  
 112          // Used to reset the screen id once views are displayed.
 113          $reset_screen_id = $this->screen->id;
 114  
 115          // Temporarly set the screen id to the users one.
 116          $this->screen->id = 'users-network';
 117  
 118          // Use the parent function so that other plugins can safely add views.
 119          parent::views();
 120  
 121          // Reset the role.
 122          $role = $reset_role;
 123  
 124          // Reset the screen id.
 125          $this->screen->id = $reset_screen_id;
 126  
 127          // Use thickbox to display the extended profile information.
 128          if ( bp_is_active( 'xprofile' ) || bp_members_site_requests_enabled() ) {
 129              add_thickbox();
 130          }
 131      }
 132  
 133      /**
 134       * Specific signups columns.
 135       *
 136       * @since 2.0.0
 137       *
 138       * @return array
 139       */
 140  	public function get_columns() {
 141  
 142          $columns = array(
 143              'cb'         => '<input type="checkbox" />',
 144              'username'   => __( 'Username',    'buddypress' ),
 145              'name'       => __( 'Name',        'buddypress' ),
 146              'email'      => __( 'Email',       'buddypress' ),
 147              'registered' => __( 'Registered',  'buddypress' ),
 148              'date_sent'  => __( 'Last Sent',   'buddypress' ),
 149              'count_sent' => __( 'Emails Sent', 'buddypress' )
 150          );
 151  
 152          /**
 153           * Filters the multisite Members signup columns.
 154           *
 155           * @since 2.0.0
 156           *
 157           * @param array $value Array of columns to display.
 158           */
 159          return apply_filters( 'bp_members_ms_signup_columns', $columns );
 160      }
 161  
 162      /**
 163       * Specific bulk actions for signups.
 164       *
 165       * @since 2.0.0
 166       */
 167  	public function get_bulk_actions() {
 168          $actions = array(
 169              'activate' => _x( 'Activate', 'Pending signup action', 'buddypress' ),
 170              'resend'   => _x( 'Email',    'Pending signup action', 'buddypress' ),
 171          );
 172  
 173          if ( current_user_can( 'delete_users' ) ) {
 174              $actions['delete'] = __( 'Delete', 'buddypress' );
 175          }
 176  
 177          /**
 178           * Filters the bulk actions for signups.
 179           *
 180           * @since 10.0.0
 181           *
 182           * @param array $actions Array of actions and corresponding labels.
 183           */
 184          return apply_filters( 'bp_members_ms_signup_bulk_actions', $actions );
 185      }
 186  
 187      /**
 188       * The text shown when no items are found.
 189       *
 190       * Nice job, clean sheet!
 191       *
 192       * @since 2.0.0
 193       */
 194  	public function no_items() {
 195          if ( bp_get_signup_allowed() || bp_get_membership_requests_required() ) {
 196              esc_html_e( 'No pending accounts found.', 'buddypress' );
 197          } else {
 198              $link = false;
 199  
 200              if ( current_user_can( 'manage_network_users' ) ) {
 201                  $link = sprintf( '<a href="%1$s">%2$s</a>', esc_url( network_admin_url( 'settings.php' ) ), esc_html__( 'Edit settings', 'buddypress' ) );
 202              }
 203  
 204              /* translators: %s: url to site settings */
 205              printf( __( 'Registration is disabled. %s', 'buddypress' ), $link );
 206          }
 207      }
 208  
 209      /**
 210       * The columns signups can be reordered with.
 211       *
 212       * @since 2.0.0
 213       */
 214  	public function get_sortable_columns() {
 215          return array(
 216              'username'   => 'login',
 217              'email'      => 'email',
 218              'registered' => 'signup_id',
 219          );
 220      }
 221  
 222      /**
 223       * Display signups rows.
 224       *
 225       * @since 2.0.0
 226       */
 227  	public function display_rows() {
 228          $style = '';
 229          foreach ( $this->items as $userid => $signup_object ) {
 230  
 231              // Avoid a notice error appearing since 4.3.0.
 232              if ( isset( $signup_object->id ) ) {
 233                  $signup_object->ID = $signup_object->id;
 234              }
 235  
 236              $style = ( ' class="alternate"' == $style ) ? '' : ' class="alternate"';
 237              echo "\n\t" . $this->single_row( $signup_object, $style );
 238          }
 239      }
 240  
 241      /**
 242       * Display a signup row.
 243       *
 244       * @since 2.0.0
 245       *
 246       * @see WP_List_Table::single_row() for explanation of params.
 247       *
 248       * @param object|null $signup_object Signup user object.
 249       * @param string      $style         Styles for the row.
 250       */
 251  	public function single_row( $signup_object = null, $style = '' ) {
 252          echo '<tr' . $style . ' id="signup-' . esc_attr( $signup_object->id ) . '">';
 253          echo $this->single_row_columns( $signup_object );
 254          echo '</tr>';
 255      }
 256  
 257      /**
 258       * Prevents regular users row actions to be output.
 259       *
 260       * @since 2.4.0
 261       *
 262       * @param object|null $signup_object Signup being acted upon.
 263       * @param string      $column_name   Current column name.
 264       * @param string      $primary       Primary column name.
 265       * @return string
 266       */
 267  	protected function handle_row_actions( $signup_object = null, $column_name = '', $primary = '' ) {
 268          return '';
 269      }
 270  
 271      /**
 272       * Markup for the checkbox used to select items for bulk actions.
 273       *
 274       * @since 2.0.0
 275       *
 276       * @param object|null $signup_object The signup data object.
 277       */
 278  	public function column_cb( $signup_object = null ) {
 279      ?>
 280          <label class="screen-reader-text" for="signup_<?php echo intval( $signup_object->id ); ?>"><?php printf(
 281              /* translators: accessibility text */
 282              esc_html__( 'Select user: %s', 'buddypress' ), $signup_object->user_login );
 283          ?></label>
 284          <input type="checkbox" id="signup_<?php echo intval( $signup_object->id ) ?>" name="allsignups[]" value="<?php echo esc_attr( $signup_object->id ) ?>" />
 285          <?php
 286      }
 287  
 288      /**
 289       * The row actions (delete/activate/email).
 290       *
 291       * @since 2.0.0
 292       *
 293       * @param object|null $signup_object The signup data object.
 294       */
 295  	public function column_username( $signup_object = null ) {
 296          $avatar    = get_avatar( $signup_object->user_email, 32 );
 297  
 298          // Activation email link.
 299          $email_link = add_query_arg(
 300              array(
 301                  'page'        => 'bp-signups',
 302                  'signup_id' => $signup_object->id,
 303                  'action'    => 'resend',
 304              ),
 305              network_admin_url( 'users.php' )
 306          );
 307  
 308          // Activate link.
 309          $activate_link = add_query_arg(
 310              array(
 311                  'page'      => 'bp-signups',
 312                  'signup_id' => $signup_object->id,
 313                  'action'    => 'activate',
 314              ),
 315              network_admin_url( 'users.php' )
 316          );
 317  
 318          // Delete link.
 319          $delete_link = add_query_arg(
 320              array(
 321                  'page'      => 'bp-signups',
 322                  'signup_id' => $signup_object->id,
 323                  'action'    => 'delete',
 324              ),
 325              network_admin_url( 'users.php' )
 326          );
 327  
 328          echo $avatar . sprintf( '<strong><a href="%1$s" class="edit">%2$s</a></strong><br/>', esc_url( $activate_link ), $signup_object->user_login );
 329  
 330          $actions = array();
 331  
 332          $actions['activate'] = sprintf( '<a href="%1$s">%2$s</a>', esc_url( $activate_link ), __( 'Activate', 'buddypress' ) );
 333          $actions['resend']   = sprintf( '<a href="%1$s">%2$s</a>', esc_url( $email_link    ), __( 'Email',    'buddypress' ) );
 334  
 335          if ( current_user_can( 'delete_users' ) ) {
 336              $actions['delete'] = sprintf( '<a href="%1$s" class="delete">%2$s</a>', esc_url( $delete_link ), __( 'Delete', 'buddypress' ) );
 337          }
 338  
 339          /** This filter is documented in bp-members/admin/bp-members-classes.php */
 340          $actions = apply_filters( 'bp_members_ms_signup_row_actions', $actions, $signup_object );
 341  
 342          echo $this->row_actions( $actions );
 343      }
 344  
 345      /**
 346       * Display user name, if any.
 347       *
 348       * @since 2.0.0
 349       *
 350       * @param object|null $signup_object The signup data object.
 351       */
 352  	public function column_name( $signup_object = null ) {
 353          echo esc_html( $signup_object->user_name );
 354  
 355          // Insert the extended profile modal content required by thickbox.
 356          if ( ! bp_is_active( 'xprofile' ) && ! bp_members_site_requests_enabled() ) {
 357              return;
 358          }
 359  
 360          if ( bp_is_active( 'xprofile' ) ) {
 361              $profile_field_ids = array();
 362  
 363              // Fetch registration field data once only.
 364              if ( ! $this->signup_field_labels ) {
 365                  $field_groups = bp_xprofile_get_groups(
 366                      array(
 367                          'fetch_fields'       => true,
 368                          'signup_fields_only' => true,
 369                      )
 370                  );
 371  
 372                  foreach ( $field_groups as $field_group ) {
 373                      foreach ( $field_group->fields as $field ) {
 374                          $this->signup_field_labels[ $field->id ] = $field->name;
 375                      }
 376                  }
 377              }
 378          }
 379  
 380          bp_members_admin_preview_signup_profile_info( $this->signup_field_labels, $signup_object );
 381      }
 382  
 383      /**
 384       * Display user email.
 385       *
 386       * @since 2.0.0
 387       *
 388       * @param object|null $signup_object The signup data object.
 389       */
 390  	public function column_email( $signup_object = null ) {
 391          printf( '<a href="mailto:%1$s">%2$s</a>', esc_attr( $signup_object->user_email ), esc_html( $signup_object->user_email ) );
 392      }
 393  
 394      /**
 395       * Display registration date.
 396       *
 397       * @since 2.0.0
 398       *
 399       * @param object|null $signup_object The signup data object.
 400       */
 401  	public function column_registered( $signup_object = null ) {
 402          global $mode;
 403  
 404          if ( 'list' === $mode ) {
 405              $date = 'Y/m/d';
 406          } else {
 407              $date = 'Y/m/d \<\b\r \/\> g:i:s a';
 408          }
 409  
 410          echo mysql2date( $date, $signup_object->registered ) . "</td>";
 411      }
 412  
 413      /**
 414       * Display the last time an activation email has been sent.
 415       *
 416       * @since 2.0.0
 417       *
 418       * @param object|null $signup_object Signup object instance.
 419       */
 420  	public function column_date_sent( $signup_object = null ) {
 421          global $mode;
 422  
 423          if ( 'list' === $mode ) {
 424              $date = 'Y/m/d';
 425          } else {
 426              $date = 'Y/m/d \<\b\r \/\> g:i:s a';
 427          }
 428  
 429          if ( $signup_object->count_sent > 0 ) {
 430              echo mysql2date( $date, $signup_object->date_sent );
 431          } else {
 432              $message = __( 'Not yet notified', 'buddypress' );
 433  
 434              /**
 435               * Filters the "not yet sent" message for "Last Sent"
 436               * column in Manage Signups list table.
 437               *
 438               * @since 10.0.0
 439               *
 440               * @param string      $message       "Not yet sent" message.
 441               * @param object|null $signup_object Signup object instance.
 442               */
 443              $message = apply_filters( 'bp_members_ms_signup_date_sent_unsent_message', $message, $signup_object );
 444  
 445              echo esc_html( $message );
 446          }
 447      }
 448  
 449      /**
 450       * Display number of time an activation email has been sent.
 451       *
 452       * @since 2.0.0
 453       *
 454       * @param object|null $signup_object Signup object instance.
 455       */
 456  	public function column_count_sent( $signup_object = null ) {
 457          echo absint( $signup_object->count_sent );
 458      }
 459  
 460      /**
 461       * Allow plugins to add their custom column.
 462       *
 463       * @since 2.1.0
 464       *
 465       * @param object|null $signup_object The signup data object.
 466       * @param string      $column_name   The column name.
 467       * @return string
 468       */
 469  	function column_default( $signup_object = null, $column_name = '' ) {
 470  
 471          /**
 472           * Filters the multisite custom columns for plugins.
 473           *
 474           * @since 2.1.0
 475           *
 476           * @param string $column_name   The column name.
 477           * @param object $signup_object The signup data object.
 478           */
 479          return apply_filters( 'bp_members_ms_signup_custom_column', '', $column_name, $signup_object );
 480      }
 481  }


Generated: Fri Sep 20 01:00:55 2024 Cross-referenced by PHPXref 0.7.1