第三步:设置用户列表角色类别
第二步完成后,基本就已经可以满足超级管理员与普通管理员直接的操作了,但是如果细心的话,你会发现列表上方的角色类别筛选列表依然会显示超级管理员和普通管理员,如图所示
这个时候我们需要像重新遍历用户列表一样,去修改此处,他这里显示的规则主要是如果该角色组下有用户的话,那么就会在此处将对应的角色名称给显示出来,然后还会带上统计数量,我这里是根据个人需要讲统计数量去掉了的,大家可以根据自己的需要去修改是否显示统计用户数量
首先打开工程目录下的wp-admin/includes/class-wp-users-list-table.php文件,找到如下代码
foreach ( $wp_roles->get_names() as $this_role => $name ) {
if ( !isset($avail_roles[$this_role]) )
continue;
$current_link_attributes = '';
if ( $this_role === $role ) {
$current_link_attributes = ' class="current" aria-current="page"';
}
$name = translate_user_role( $name );
/* translators: User role name with count */
$name = sprintf( __('%1$s <span class="count">(%2$s)</span>'), $name,
number_format_i18n( $avail_roles[$this_role] ) );
$role_links[$this_role] = "<a href='" . esc_url( add_query_arg( 'role', $this_role, $url ) ) . "'$current_link_attributes>$name</a>";
}
此处主要是显示刚才所展示的角色类别筛选列表,我这里的修改很简单,根据当前用户登录的权限去判断,去除对应的角色名,例如:超级管理员权限的用户只显示普通管理员及普通角色,普通管理员权限用户只显示普通角色,主要是将$wp_roles->get_names()中的超级管理员的角色标识和普通管理员的角色标识根据登录权限去掉即可,这就是为什么之前要记住创建角色名所输入的角色标识原因。
由于要对角色进行修改,所以要先将foreach做如下修改:
修改前:
foreach ( $wp_roles->get_names() as $this_role => $name )
修改后:
$newRole = $wp_roles->get_names();
foreach ( $newRole as $this_role => $name )
然后根据用户的登录权限去掉对应的角色标识,在foreach与$newRole的中间添加如下代码
global $current_user;
if( $current_user->roles[0] == 'administrator' ) {
unset($newRole['administrator']);
}else{
unset($newRole['administrator'],$newRole['admin']);
}
至此,就已经修改完成,效果如下:
超级管理员:
普通管理员: