From 95ba2c38c0325d4d4b5d5fcc819c25c70d865b8c Mon Sep 17 00:00:00 2001 From: jeremyfelt Date: Wed, 24 Feb 2016 21:42:02 +0000 Subject: [PATCH] Multisite: Provide an "Edit user" link after adding a new user Props codex-m, jeremyfelt. Fixes #35705. git-svn-id: https://develop.svn.wordpress.org/trunk@36695 602fd350-edb4-49c9-b593-d223f7449a82 --- src/wp-admin/network/user-new.php | 19 ++++++++++++++++--- src/wp-admin/user-edit.php | 4 ++-- src/wp-admin/user-new.php | 24 ++++++++++++++++++++---- 3 files changed, 38 insertions(+), 9 deletions(-) diff --git a/src/wp-admin/network/user-new.php b/src/wp-admin/network/user-new.php index 62d5752caa..b86d4234d3 100644 --- a/src/wp-admin/network/user-new.php +++ b/src/wp-admin/network/user-new.php @@ -59,7 +59,7 @@ if ( isset($_REQUEST['action']) && 'add-user' == $_REQUEST['action'] ) { * @param int $user_id ID of the newly created user. */ do_action( 'network_user_new_created_user', $user_id ); - wp_redirect( add_query_arg( array('update' => 'added'), 'user-new.php' ) ); + wp_redirect( add_query_arg( array('update' => 'added', 'user_id' => $user_id ), 'user-new.php' ) ); exit; } } @@ -67,8 +67,21 @@ if ( isset($_REQUEST['action']) && 'add-user' == $_REQUEST['action'] ) { if ( isset($_GET['update']) ) { $messages = array(); - if ( 'added' == $_GET['update'] ) - $messages[] = __('User added.'); + if ( 'added' == $_GET['update'] ) { + $edit_link = ''; + if ( isset( $_GET['user_id'] ) ) { + $user_id_new = absint( $_GET['user_id'] ); + if ( $user_id_new ) { + $edit_link = esc_url( add_query_arg( 'wp_http_referer', urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ), get_edit_user_link( $user_id_new ) ) ); + } + } + + if ( empty( $edit_link ) ) { + $messages[] = __( 'User added.' ); + } else { + $messages[] = sprintf( __( 'User added. Edit User' ), $edit_link ); + } + } } $title = __('Add New User'); diff --git a/src/wp-admin/user-edit.php b/src/wp-admin/user-edit.php index bbf21f4510..3ecfe0a455 100644 --- a/src/wp-admin/user-edit.php +++ b/src/wp-admin/user-edit.php @@ -55,7 +55,7 @@ get_current_screen()->set_help_sidebar( '

' . __('Support Forums') . '

' ); -$wp_http_referer = remove_query_arg(array('update', 'delete_count'), $wp_http_referer ); +$wp_http_referer = remove_query_arg( array( 'update', 'delete_count', 'user_id' ), $wp_http_referer ); $user_can_edit = current_user_can( 'edit_posts' ) || current_user_can( 'edit_pages' ); @@ -179,7 +179,7 @@ include(ABSPATH . 'wp-admin/admin-header.php');

- +

diff --git a/src/wp-admin/user-new.php b/src/wp-admin/user-new.php index ff0bffb840..5400be255b 100644 --- a/src/wp-admin/user-new.php +++ b/src/wp-admin/user-new.php @@ -68,7 +68,7 @@ if ( isset($_REQUEST['action']) && 'adduser' == $_REQUEST['action'] ) { } else { if ( isset( $_POST[ 'noconfirmation' ] ) && current_user_can( 'manage_network_users' ) ) { add_existing_user_to_blog( array( 'user_id' => $user_id, 'role' => $_REQUEST[ 'role' ] ) ); - $redirect = add_query_arg( array('update' => 'addnoconfirmation'), 'user-new.php' ); + $redirect = add_query_arg( array( 'update' => 'addnoconfirmation' , 'user_id' => $user_id ), 'user-new.php' ); } else { $newuser_key = substr( md5( $user_id ), 0, 5 ); add_option( 'new_user_' . $newuser_key, array( 'user_id' => $user_id, 'email' => $user_details->user_email, 'role' => $_REQUEST[ 'role' ] ) ); @@ -147,8 +147,12 @@ Please click the following link to confirm the invite: wpmu_signup_user( $new_user_login, $new_user_email, array( 'add_to_blog' => $wpdb->blogid, 'new_role' => $_REQUEST['role'] ) ); if ( isset( $_POST[ 'noconfirmation' ] ) && current_user_can( 'manage_network_users' ) ) { $key = $wpdb->get_var( $wpdb->prepare( "SELECT activation_key FROM {$wpdb->signups} WHERE user_login = %s AND user_email = %s", $new_user_login, $new_user_email ) ); - wpmu_activate_signup( $key ); - $redirect = add_query_arg( array('update' => 'addnoconfirmation'), 'user-new.php' ); + $new_user = wpmu_activate_signup( $key ); + if ( ! is_wp_error( $new_user ) ) { + $redirect = add_query_arg( array( 'update' => 'addnoconfirmation' ), 'user-new.php' ); + } else { + $redirect = add_query_arg( array( 'update' => 'addnoconfirmation', 'user_id' => $new_user['user_id'] ), 'user-new.php' ); + } } else { $redirect = add_query_arg( array('update' => 'newuserconfirmation'), 'user-new.php' ); } @@ -223,6 +227,14 @@ require_once( ABSPATH . 'wp-admin/admin-header.php' ); if ( isset($_GET['update']) ) { $messages = array(); if ( is_multisite() ) { + $edit_link = ''; + if ( ( isset( $_GET['user_id'] ) ) ) { + $user_id_new = absint( $_GET['user_id'] ); + if ( $user_id_new ) { + $edit_link = esc_url( add_query_arg( 'wp_http_referer', urlencode( wp_unslash( $_SERVER['REQUEST_URI'] ) ), get_edit_user_link( $user_id_new ) ) ); + } + } + switch ( $_GET['update'] ) { case "newuserconfirmation": $messages[] = __('Invitation email sent to new user. A confirmation link must be clicked before their account is created.'); @@ -231,7 +243,11 @@ if ( isset($_GET['update']) ) { $messages[] = __('Invitation email sent to user. A confirmation link must be clicked for them to be added to your site.'); break; case "addnoconfirmation": - $messages[] = __('User has been added to your site.'); + if ( empty( $edit_link ) ) { + $messages[] = __( 'User has been added to your site.' ); + } else { + $messages[] = sprintf( __( 'User has been added to your site. Edit User' ), $edit_link ); + } break; case "addexisting": $messages[] = __('That user is already a member of this site.');