[ Index ] |
PHP Cross Reference of WordPress |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * User administration panel 4 * 5 * @package WordPress 6 * @subpackage Administration 7 * @since 1.0.0 8 */ 9 10 /** WordPress Administration Bootstrap */ 11 require_once __DIR__ . '/admin.php'; 12 13 if ( ! current_user_can( 'list_users' ) ) { 14 wp_die( 15 '<h1>' . __( 'You need a higher level of permission.' ) . '</h1>' . 16 '<p>' . __( 'Sorry, you are not allowed to list users.' ) . '</p>', 17 403 18 ); 19 } 20 21 $wp_list_table = _get_list_table( 'WP_Users_List_Table' ); 22 $pagenum = $wp_list_table->get_pagenum(); 23 24 // Used in the HTML title tag. 25 $title = __( 'Users' ); 26 $parent_file = 'users.php'; 27 28 add_screen_option( 'per_page' ); 29 30 // Contextual help - choose Help on the top right of admin panel to preview this. 31 get_current_screen()->add_help_tab( 32 array( 33 'id' => 'overview', 34 'title' => __( 'Overview' ), 35 'content' => '<p>' . __( 'This screen lists all the existing users for your site. Each user has one of five defined roles as set by the site admin: Site Administrator, Editor, Author, Contributor, or Subscriber. Users with roles other than Administrator will see fewer options in the dashboard navigation when they are logged in, based on their role.' ) . '</p>' . 36 '<p>' . __( 'To add a new user for your site, click the Add New button at the top of the screen or Add New in the Users menu section.' ) . '</p>', 37 ) 38 ); 39 40 get_current_screen()->add_help_tab( 41 array( 42 'id' => 'screen-content', 43 'title' => __( 'Screen Content' ), 44 'content' => '<p>' . __( 'You can customize the display of this screen in a number of ways:' ) . '</p>' . 45 '<ul>' . 46 '<li>' . __( 'You can hide/display columns based on your needs and decide how many users to list per screen using the Screen Options tab.' ) . '</li>' . 47 '<li>' . __( 'You can filter the list of users by User Role using the text links above the users list to show All, Administrator, Editor, Author, Contributor, or Subscriber. The default view is to show all users. Unused User Roles are not listed.' ) . '</li>' . 48 '<li>' . __( 'You can view all posts made by a user by clicking on the number under the Posts column.' ) . '</li>' . 49 '</ul>', 50 ) 51 ); 52 53 $help = '<p>' . __( 'Hovering over a row in the users list will display action links that allow you to manage users. You can perform the following actions:' ) . '</p>' . 54 '<ul>' . 55 '<li>' . __( '<strong>Edit</strong> takes you to the editable profile screen for that user. You can also reach that screen by clicking on the username.' ) . '</li>'; 56 57 if ( is_multisite() ) { 58 $help .= '<li>' . __( '<strong>Remove</strong> allows you to remove a user from your site. It does not delete their content. You can also remove multiple users at once by using bulk actions.' ) . '</li>'; 59 } else { 60 $help .= '<li>' . __( '<strong>Delete</strong> brings you to the Delete Users screen for confirmation, where you can permanently remove a user from your site and delete their content. You can also delete multiple users at once by using bulk actions.' ) . '</li>'; 61 } 62 63 $help .= '</ul>'; 64 65 get_current_screen()->add_help_tab( 66 array( 67 'id' => 'action-links', 68 'title' => __( 'Available Actions' ), 69 'content' => $help, 70 ) 71 ); 72 unset( $help ); 73 74 get_current_screen()->set_help_sidebar( 75 '<p><strong>' . __( 'For more information:' ) . '</strong></p>' . 76 '<p>' . __( '<a href="https://wordpress.org/support/article/users-screen/">Documentation on Managing Users</a>' ) . '</p>' . 77 '<p>' . __( '<a href="https://wordpress.org/support/article/roles-and-capabilities/">Descriptions of Roles and Capabilities</a>' ) . '</p>' . 78 '<p>' . __( '<a href="https://wordpress.org/support/">Support</a>' ) . '</p>' 79 ); 80 81 get_current_screen()->set_screen_reader_content( 82 array( 83 'heading_views' => __( 'Filter users list' ), 84 'heading_pagination' => __( 'Users list navigation' ), 85 'heading_list' => __( 'Users list' ), 86 ) 87 ); 88 89 if ( empty( $_REQUEST ) ) { 90 $referer = '<input type="hidden" name="wp_http_referer" value="' . esc_attr( wp_unslash( $_SERVER['REQUEST_URI'] ) ) . '" />'; 91 } elseif ( isset( $_REQUEST['wp_http_referer'] ) ) { 92 $redirect = remove_query_arg( array( 'wp_http_referer', 'updated', 'delete_count' ), wp_unslash( $_REQUEST['wp_http_referer'] ) ); 93 $referer = '<input type="hidden" name="wp_http_referer" value="' . esc_attr( $redirect ) . '" />'; 94 } else { 95 $redirect = 'users.php'; 96 $referer = ''; 97 } 98 99 $update = ''; 100 101 switch ( $wp_list_table->current_action() ) { 102 103 /* Bulk Dropdown menu Role changes */ 104 case 'promote': 105 check_admin_referer( 'bulk-users' ); 106 107 if ( ! current_user_can( 'promote_users' ) ) { 108 wp_die( __( 'Sorry, you are not allowed to edit this user.' ), 403 ); 109 } 110 111 if ( empty( $_REQUEST['users'] ) ) { 112 wp_redirect( $redirect ); 113 exit; 114 } 115 116 $editable_roles = get_editable_roles(); 117 $role = $_REQUEST['new_role']; 118 119 // Mocking the `none` role so we are able to save it to the database 120 $editable_roles['none'] = array( 121 'name' => __( '— No role for this site —' ), 122 ); 123 124 if ( ! $role || empty( $editable_roles[ $role ] ) ) { 125 wp_die( __( 'Sorry, you are not allowed to give users that role.' ), 403 ); 126 } 127 128 if ( 'none' === $role ) { 129 $role = ''; 130 } 131 132 $userids = $_REQUEST['users']; 133 $update = 'promote'; 134 foreach ( $userids as $id ) { 135 $id = (int) $id; 136 137 if ( ! current_user_can( 'promote_user', $id ) ) { 138 wp_die( __( 'Sorry, you are not allowed to edit this user.' ), 403 ); 139 } 140 141 // The new role of the current user must also have the promote_users cap or be a multisite super admin. 142 if ( $id == $current_user->ID && ! $wp_roles->role_objects[ $role ]->has_cap( 'promote_users' ) 143 && ! ( is_multisite() && current_user_can( 'manage_network_users' ) ) ) { 144 $update = 'err_admin_role'; 145 continue; 146 } 147 148 // If the user doesn't already belong to the blog, bail. 149 if ( is_multisite() && ! is_user_member_of_blog( $id ) ) { 150 wp_die( 151 '<h1>' . __( 'Something went wrong.' ) . '</h1>' . 152 '<p>' . __( 'One of the selected users is not a member of this site.' ) . '</p>', 153 403 154 ); 155 } 156 157 $user = get_userdata( $id ); 158 $user->set_role( $role ); 159 } 160 161 wp_redirect( add_query_arg( 'update', $update, $redirect ) ); 162 exit; 163 164 case 'dodelete': 165 if ( is_multisite() ) { 166 wp_die( __( 'User deletion is not allowed from this screen.' ), 400 ); 167 } 168 169 check_admin_referer( 'delete-users' ); 170 171 if ( empty( $_REQUEST['users'] ) ) { 172 wp_redirect( $redirect ); 173 exit; 174 } 175 176 $userids = array_map( 'intval', (array) $_REQUEST['users'] ); 177 178 if ( empty( $_REQUEST['delete_option'] ) ) { 179 $url = self_admin_url( 'users.php?action=delete&users[]=' . implode( '&users[]=', $userids ) . '&error=true' ); 180 $url = str_replace( '&', '&', wp_nonce_url( $url, 'bulk-users' ) ); 181 wp_redirect( $url ); 182 exit; 183 } 184 185 if ( ! current_user_can( 'delete_users' ) ) { 186 wp_die( __( 'Sorry, you are not allowed to delete users.' ), 403 ); 187 } 188 189 $update = 'del'; 190 $delete_count = 0; 191 192 foreach ( $userids as $id ) { 193 if ( ! current_user_can( 'delete_user', $id ) ) { 194 wp_die( __( 'Sorry, you are not allowed to delete that user.' ), 403 ); 195 } 196 197 if ( $id == $current_user->ID ) { 198 $update = 'err_admin_del'; 199 continue; 200 } 201 switch ( $_REQUEST['delete_option'] ) { 202 case 'delete': 203 wp_delete_user( $id ); 204 break; 205 case 'reassign': 206 wp_delete_user( $id, $_REQUEST['reassign_user'] ); 207 break; 208 } 209 ++$delete_count; 210 } 211 212 $redirect = add_query_arg( 213 array( 214 'delete_count' => $delete_count, 215 'update' => $update, 216 ), 217 $redirect 218 ); 219 wp_redirect( $redirect ); 220 exit; 221 222 case 'resetpassword': 223 check_admin_referer( 'bulk-users' ); 224 if ( ! current_user_can( 'edit_users' ) ) { 225 $errors = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to edit users.' ) ); 226 } 227 if ( empty( $_REQUEST['users'] ) ) { 228 wp_redirect( $redirect ); 229 exit(); 230 } 231 $userids = array_map( 'intval', (array) $_REQUEST['users'] ); 232 233 $reset_count = 0; 234 235 foreach ( $userids as $id ) { 236 if ( ! current_user_can( 'edit_user', $id ) ) { 237 wp_die( __( 'Sorry, you are not allowed to edit this user.' ) ); 238 } 239 240 if ( $id === $current_user->ID ) { 241 $update = 'err_admin_reset'; 242 continue; 243 } 244 245 // Send the password reset link. 246 $user = get_userdata( $id ); 247 if ( retrieve_password( $user->user_login ) ) { 248 ++$reset_count; 249 } 250 } 251 252 $redirect = add_query_arg( 253 array( 254 'reset_count' => $reset_count, 255 'update' => 'resetpassword', 256 ), 257 $redirect 258 ); 259 wp_redirect( $redirect ); 260 exit; 261 262 case 'delete': 263 if ( is_multisite() ) { 264 wp_die( __( 'User deletion is not allowed from this screen.' ), 400 ); 265 } 266 267 check_admin_referer( 'bulk-users' ); 268 269 if ( empty( $_REQUEST['users'] ) && empty( $_REQUEST['user'] ) ) { 270 wp_redirect( $redirect ); 271 exit; 272 } 273 274 if ( ! current_user_can( 'delete_users' ) ) { 275 $errors = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to delete users.' ) ); 276 } 277 278 if ( empty( $_REQUEST['users'] ) ) { 279 $userids = array( (int) $_REQUEST['user'] ); 280 } else { 281 $userids = array_map( 'intval', (array) $_REQUEST['users'] ); 282 } 283 284 $all_userids = $userids; 285 286 if ( in_array( $current_user->ID, $userids, true ) ) { 287 $userids = array_diff( $userids, array( $current_user->ID ) ); 288 } 289 290 /** 291 * Filters whether the users being deleted have additional content 292 * associated with them outside of the `post_author` and `link_owner` relationships. 293 * 294 * @since 5.2.0 295 * 296 * @param bool $users_have_additional_content Whether the users have additional content. Default false. 297 * @param int[] $userids Array of IDs for users being deleted. 298 */ 299 $users_have_content = (bool) apply_filters( 'users_have_additional_content', false, $userids ); 300 301 if ( $userids && ! $users_have_content ) { 302 if ( $wpdb->get_var( "SELECT ID FROM {$wpdb->posts} WHERE post_author IN( " . implode( ',', $userids ) . ' ) LIMIT 1' ) ) { 303 $users_have_content = true; 304 } elseif ( $wpdb->get_var( "SELECT link_id FROM {$wpdb->links} WHERE link_owner IN( " . implode( ',', $userids ) . ' ) LIMIT 1' ) ) { 305 $users_have_content = true; 306 } 307 } 308 309 if ( $users_have_content ) { 310 add_action( 'admin_head', 'delete_users_add_js' ); 311 } 312 313 require_once ABSPATH . 'wp-admin/admin-header.php'; 314 ?> 315 <form method="post" name="updateusers" id="updateusers"> 316 <?php wp_nonce_field( 'delete-users' ); ?> 317 <?php echo $referer; ?> 318 319 <div class="wrap"> 320 <h1><?php _e( 'Delete Users' ); ?></h1> 321 <?php if ( isset( $_REQUEST['error'] ) ) : ?> 322 <div class="error"> 323 <p><strong><?php _e( 'Error:' ); ?></strong> <?php _e( 'Please select an option.' ); ?></p> 324 </div> 325 <?php endif; ?> 326 327 <?php if ( 1 === count( $all_userids ) ) : ?> 328 <p><?php _e( 'You have specified this user for deletion:' ); ?></p> 329 <?php else : ?> 330 <p><?php _e( 'You have specified these users for deletion:' ); ?></p> 331 <?php endif; ?> 332 333 <ul> 334 <?php 335 $go_delete = 0; 336 foreach ( $all_userids as $id ) { 337 $user = get_userdata( $id ); 338 if ( $id == $current_user->ID ) { 339 /* translators: 1: User ID, 2: User login. */ 340 echo '<li>' . sprintf( __( 'ID #%1$s: %2$s <strong>The current user will not be deleted.</strong>' ), $id, $user->user_login ) . "</li>\n"; 341 } else { 342 /* translators: 1: User ID, 2: User login. */ 343 echo '<li><input type="hidden" name="users[]" value="' . esc_attr( $id ) . '" />' . sprintf( __( 'ID #%1$s: %2$s' ), $id, $user->user_login ) . "</li>\n"; 344 $go_delete++; 345 } 346 } 347 ?> 348 </ul> 349 <?php 350 if ( $go_delete ) : 351 352 if ( ! $users_have_content ) : 353 ?> 354 <input type="hidden" name="delete_option" value="delete" /> 355 <?php else : ?> 356 <?php if ( 1 == $go_delete ) : ?> 357 <fieldset><p><legend><?php _e( 'What should be done with content owned by this user?' ); ?></legend></p> 358 <?php else : ?> 359 <fieldset><p><legend><?php _e( 'What should be done with content owned by these users?' ); ?></legend></p> 360 <?php endif; ?> 361 <ul style="list-style:none;"> 362 <li><label><input type="radio" id="delete_option0" name="delete_option" value="delete" /> 363 <?php _e( 'Delete all content.' ); ?></label></li> 364 <li><input type="radio" id="delete_option1" name="delete_option" value="reassign" /> 365 <?php 366 echo '<label for="delete_option1">' . __( 'Attribute all content to:' ) . '</label> '; 367 wp_dropdown_users( 368 array( 369 'name' => 'reassign_user', 370 'exclude' => $userids, 371 'show' => 'display_name_with_login', 372 ) 373 ); 374 ?> 375 </li> 376 </ul></fieldset> 377 <?php 378 endif; 379 /** 380 * Fires at the end of the delete users form prior to the confirm button. 381 * 382 * @since 4.0.0 383 * @since 4.5.0 The `$userids` parameter was added. 384 * 385 * @param WP_User $current_user WP_User object for the current user. 386 * @param int[] $userids Array of IDs for users being deleted. 387 */ 388 do_action( 'delete_user_form', $current_user, $userids ); 389 ?> 390 <input type="hidden" name="action" value="dodelete" /> 391 <?php submit_button( __( 'Confirm Deletion' ), 'primary' ); ?> 392 <?php else : ?> 393 <p><?php _e( 'There are no valid users selected for deletion.' ); ?></p> 394 <?php endif; ?> 395 </div> 396 </form> 397 <?php 398 399 break; 400 401 case 'doremove': 402 check_admin_referer( 'remove-users' ); 403 404 if ( ! is_multisite() ) { 405 wp_die( __( 'You cannot remove users.' ), 400 ); 406 } 407 408 if ( empty( $_REQUEST['users'] ) ) { 409 wp_redirect( $redirect ); 410 exit; 411 } 412 413 if ( ! current_user_can( 'remove_users' ) ) { 414 wp_die( __( 'Sorry, you are not allowed to remove users.' ), 403 ); 415 } 416 417 $userids = $_REQUEST['users']; 418 419 $update = 'remove'; 420 foreach ( $userids as $id ) { 421 $id = (int) $id; 422 if ( ! current_user_can( 'remove_user', $id ) ) { 423 $update = 'err_admin_remove'; 424 continue; 425 } 426 remove_user_from_blog( $id, $blog_id ); 427 } 428 429 $redirect = add_query_arg( array( 'update' => $update ), $redirect ); 430 wp_redirect( $redirect ); 431 exit; 432 433 case 'remove': 434 check_admin_referer( 'bulk-users' ); 435 436 if ( ! is_multisite() ) { 437 wp_die( __( 'You cannot remove users.' ), 400 ); 438 } 439 440 if ( empty( $_REQUEST['users'] ) && empty( $_REQUEST['user'] ) ) { 441 wp_redirect( $redirect ); 442 exit; 443 } 444 445 if ( ! current_user_can( 'remove_users' ) ) { 446 $error = new WP_Error( 'edit_users', __( 'Sorry, you are not allowed to remove users.' ) ); 447 } 448 449 if ( empty( $_REQUEST['users'] ) ) { 450 $userids = array( (int) $_REQUEST['user'] ); 451 } else { 452 $userids = $_REQUEST['users']; 453 } 454 455 require_once ABSPATH . 'wp-admin/admin-header.php'; 456 ?> 457 <form method="post" name="updateusers" id="updateusers"> 458 <?php wp_nonce_field( 'remove-users' ); ?> 459 <?php echo $referer; ?> 460 461 <div class="wrap"> 462 <h1><?php _e( 'Remove Users from Site' ); ?></h1> 463 464 <?php if ( 1 === count( $userids ) ) : ?> 465 <p><?php _e( 'You have specified this user for removal:' ); ?></p> 466 <?php else : ?> 467 <p><?php _e( 'You have specified these users for removal:' ); ?></p> 468 <?php endif; ?> 469 470 <ul> 471 <?php 472 $go_remove = false; 473 foreach ( $userids as $id ) { 474 $id = (int) $id; 475 $user = get_userdata( $id ); 476 if ( ! current_user_can( 'remove_user', $id ) ) { 477 /* translators: 1: User ID, 2: User login. */ 478 echo '<li>' . sprintf( __( 'ID #%1$s: %2$s <strong>Sorry, you are not allowed to remove this user.</strong>' ), $id, $user->user_login ) . "</li>\n"; 479 } else { 480 /* translators: 1: User ID, 2: User login. */ 481 echo "<li><input type=\"hidden\" name=\"users[]\" value=\"{$id}\" />" . sprintf( __( 'ID #%1$s: %2$s' ), $id, $user->user_login ) . "</li>\n"; 482 $go_remove = true; 483 } 484 } 485 ?> 486 </ul> 487 <?php if ( $go_remove ) : ?> 488 <input type="hidden" name="action" value="doremove" /> 489 <?php submit_button( __( 'Confirm Removal' ), 'primary' ); ?> 490 <?php else : ?> 491 <p><?php _e( 'There are no valid users selected for removal.' ); ?></p> 492 <?php endif; ?> 493 </div> 494 </form> 495 <?php 496 497 break; 498 499 default: 500 if ( ! empty( $_GET['_wp_http_referer'] ) ) { 501 wp_redirect( remove_query_arg( array( '_wp_http_referer', '_wpnonce' ), wp_unslash( $_SERVER['REQUEST_URI'] ) ) ); 502 exit; 503 } 504 505 if ( $wp_list_table->current_action() && ! empty( $_REQUEST['users'] ) ) { 506 $screen = get_current_screen()->id; 507 $sendback = wp_get_referer(); 508 $userids = $_REQUEST['users']; 509 510 /** This action is documented in wp-admin/edit.php */ 511 $sendback = apply_filters( "handle_bulk_actions-{$screen}", $sendback, $wp_list_table->current_action(), $userids ); // phpcs:ignore WordPress.NamingConventions.ValidHookName.UseUnderscores 512 513 wp_safe_redirect( $sendback ); 514 exit; 515 } 516 517 $wp_list_table->prepare_items(); 518 $total_pages = $wp_list_table->get_pagination_arg( 'total_pages' ); 519 if ( $pagenum > $total_pages && $total_pages > 0 ) { 520 wp_redirect( add_query_arg( 'paged', $total_pages ) ); 521 exit; 522 } 523 524 require_once ABSPATH . 'wp-admin/admin-header.php'; 525 526 $messages = array(); 527 if ( isset( $_GET['update'] ) ) : 528 switch ( $_GET['update'] ) { 529 case 'del': 530 case 'del_many': 531 $delete_count = isset( $_GET['delete_count'] ) ? (int) $_GET['delete_count'] : 0; 532 if ( 1 == $delete_count ) { 533 $message = __( 'User deleted.' ); 534 } else { 535 /* translators: %s: Number of users. */ 536 $message = _n( '%s user deleted.', '%s users deleted.', $delete_count ); 537 } 538 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . sprintf( $message, number_format_i18n( $delete_count ) ) . '</p></div>'; 539 break; 540 case 'add': 541 $message = __( 'New user created.' ); 542 543 $user_id = isset( $_GET['id'] ) ? $_GET['id'] : false; 544 if ( $user_id && current_user_can( 'edit_user', $user_id ) ) { 545 $message .= sprintf( 546 ' <a href="%s">%s</a>', 547 esc_url( 548 add_query_arg( 549 'wp_http_referer', 550 urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ), 551 self_admin_url( 'user-edit.php?user_id=' . $user_id ) 552 ) 553 ), 554 __( 'Edit user' ) 555 ); 556 } 557 558 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . $message . '</p></div>'; 559 break; 560 case 'resetpassword': 561 $reset_count = isset( $_GET['reset_count'] ) ? (int) $_GET['reset_count'] : 0; 562 if ( 1 === $reset_count ) { 563 $message = __( 'Password reset link sent.' ); 564 } else { 565 /* translators: %s: Number of users. */ 566 $message = _n( 'Password reset links sent to %s user.', 'Password reset links sent to %s users.', $reset_count ); 567 } 568 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . sprintf( $message, number_format_i18n( $reset_count ) ) . '</p></div>'; 569 break; 570 case 'promote': 571 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . __( 'Changed roles.' ) . '</p></div>'; 572 break; 573 case 'err_admin_role': 574 $messages[] = '<div id="message" class="error notice is-dismissible"><p>' . __( 'The current user’s role must have user editing capabilities.' ) . '</p></div>'; 575 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . __( 'Other user roles have been changed.' ) . '</p></div>'; 576 break; 577 case 'err_admin_del': 578 $messages[] = '<div id="message" class="error notice is-dismissible"><p>' . __( 'You cannot delete the current user.' ) . '</p></div>'; 579 $messages[] = '<div id="message" class="updated notice is-dismissible"><p>' . __( 'Other users have been deleted.' ) . '</p></div>'; 580 break; 581 case 'remove': 582 $messages[] = '<div id="message" class="updated notice is-dismissible fade"><p>' . __( 'User removed from this site.' ) . '</p></div>'; 583 break; 584 case 'err_admin_remove': 585 $messages[] = '<div id="message" class="error notice is-dismissible"><p>' . __( 'You cannot remove the current user.' ) . '</p></div>'; 586 $messages[] = '<div id="message" class="updated notice is-dismissible fade"><p>' . __( 'Other users have been removed.' ) . '</p></div>'; 587 break; 588 } 589 endif; 590 ?> 591 592 <?php if ( isset( $errors ) && is_wp_error( $errors ) ) : ?> 593 <div class="error"> 594 <ul> 595 <?php 596 foreach ( $errors->get_error_messages() as $err ) { 597 echo "<li>$err</li>\n"; 598 } 599 ?> 600 </ul> 601 </div> 602 <?php 603 endif; 604 605 if ( ! empty( $messages ) ) { 606 foreach ( $messages as $msg ) { 607 echo $msg; 608 } 609 } 610 ?> 611 612 <div class="wrap"> 613 <h1 class="wp-heading-inline"> 614 <?php 615 echo esc_html( $title ); 616 ?> 617 </h1> 618 619 <?php 620 if ( current_user_can( 'create_users' ) ) { 621 ?> 622 <a href="<?php echo esc_url( admin_url( 'user-new.php' ) ); ?>" class="page-title-action"><?php echo esc_html_x( 'Add New', 'user' ); ?></a> 623 <?php } elseif ( is_multisite() && current_user_can( 'promote_users' ) ) { ?> 624 <a href="<?php echo esc_url( admin_url( 'user-new.php' ) ); ?>" class="page-title-action"><?php echo esc_html_x( 'Add Existing', 'user' ); ?></a> 625 <?php 626 } 627 628 if ( strlen( $usersearch ) ) { 629 echo '<span class="subtitle">'; 630 printf( 631 /* translators: %s: Search query. */ 632 __( 'Search results for: %s' ), 633 '<strong>' . esc_html( $usersearch ) . '</strong>' 634 ); 635 echo '</span>'; 636 } 637 ?> 638 639 <hr class="wp-header-end"> 640 641 <?php $wp_list_table->views(); ?> 642 643 <form method="get"> 644 645 <?php $wp_list_table->search_box( __( 'Search Users' ), 'user' ); ?> 646 647 <?php if ( ! empty( $_REQUEST['role'] ) ) { ?> 648 <input type="hidden" name="role" value="<?php echo esc_attr( $_REQUEST['role'] ); ?>" /> 649 <?php } ?> 650 651 <?php $wp_list_table->display(); ?> 652 </form> 653 654 <div class="clear"></div> 655 </div> 656 <?php 657 break; 658 659 } // End of the $doaction switch. 660 661 require_once ABSPATH . 'wp-admin/admin-footer.php';
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Sun Dec 22 01:00:02 2024 | Cross-referenced by PHPXref 0.7.1 |