Add user deletion
This commit is contained in:
@ -5,6 +5,7 @@
|
|||||||
@using Microsoft.AspNetCore.Authorization
|
@using Microsoft.AspNetCore.Authorization
|
||||||
@using Microsoft.AspNetCore.Identity
|
@using Microsoft.AspNetCore.Identity
|
||||||
@using Microsoft.EntityFrameworkCore
|
@using Microsoft.EntityFrameworkCore
|
||||||
|
@using System.IdentityModel.Claims
|
||||||
|
|
||||||
@attribute [Authorize]
|
@attribute [Authorize]
|
||||||
|
|
||||||
@ -29,14 +30,19 @@
|
|||||||
</RadzenRow>
|
</RadzenRow>
|
||||||
<RadzenRow>
|
<RadzenRow>
|
||||||
<RadzenColumn SizeMD="12">
|
<RadzenColumn SizeMD="12">
|
||||||
<!--<RadzenAlert AlertStyle="AlertStyle.Danger" Variant="Variant.Flat" Shade="Shade.Lighter" Title="" Visible="@errorVisible">@error</RadzenAlert>-->
|
<RadzenAlert Visible="@hasError" AlertStyle="AlertStyle.Danger" Variant="Variant.Flat" Shade="Shade.Lighter" AllowClose="false">
|
||||||
|
@errorMessage
|
||||||
|
</RadzenAlert>
|
||||||
<RadzenDataGrid TItem="AppUserWithRole" Data="@usersWithRoles" RowSelect="@EditUser" IsLoading="@isLoading" AllowFiltering="true" AllowPaging="true" ShowPagingSummary="true" PageSizeOptions=@(new int[] { 5, 10, 20, 30 }) AllowSorting="true">
|
<RadzenDataGrid TItem="AppUserWithRole" Data="@usersWithRoles" RowSelect="@EditUser" IsLoading="@isLoading" AllowFiltering="true" AllowPaging="true" ShowPagingSummary="true" PageSizeOptions=@(new int[] { 5, 10, 20, 30 }) AllowSorting="true">
|
||||||
<Columns>
|
<Columns>
|
||||||
<RadzenDataGridColumn TItem="AppUserWithRole" Property="User.UserName" Title="Логин" />
|
<RadzenDataGridColumn TItem="AppUserWithRole" Property="User.UserName" Title="Логин" />
|
||||||
<RadzenDataGridColumn TItem="AppUserWithRole" Property="Role.Name" Title="Роль" />
|
<RadzenDataGridColumn TItem="AppUserWithRole" Property="Role.Name" Title="Роль" />
|
||||||
<RadzenDataGridColumn TItem="AppUserWithRole" Filterable="false" Sortable="false" TextAlign="TextAlign.Center" Width="70px">
|
<RadzenDataGridColumn TItem="AppUserWithRole" Filterable="false" Sortable="false" TextAlign="TextAlign.Center" Width="70px">
|
||||||
<Template Context="userWithRole">
|
<Template Context="userWithRole">
|
||||||
<RadzenButton Click="@(() => DeleteUser(userWithRole))" @onclick:stopPropagation="true" ButtonStyle="ButtonStyle.Danger" Icon="close" Size="ButtonSize.Small" />
|
@if (userWithRole.User.Id != currentUserId)
|
||||||
|
{
|
||||||
|
<RadzenButton Click="@(() => DeleteUser(userWithRole))" @onclick:stopPropagation="true" ButtonStyle="ButtonStyle.Danger" Icon="close" Size="ButtonSize.Small" />
|
||||||
|
}
|
||||||
</Template>
|
</Template>
|
||||||
</RadzenDataGridColumn>
|
</RadzenDataGridColumn>
|
||||||
</Columns>
|
</Columns>
|
||||||
@ -48,8 +54,11 @@
|
|||||||
</AuthorizedContent>
|
</AuthorizedContent>
|
||||||
|
|
||||||
@code {
|
@code {
|
||||||
|
string currentUserId;
|
||||||
IEnumerable<AppUserWithRole> usersWithRoles;
|
IEnumerable<AppUserWithRole> usersWithRoles;
|
||||||
bool isLoading;
|
bool isLoading;
|
||||||
|
bool hasError;
|
||||||
|
string errorMessage;
|
||||||
|
|
||||||
protected override async Task OnAfterRenderAsync(bool firstRender)
|
protected override async Task OnAfterRenderAsync(bool firstRender)
|
||||||
{
|
{
|
||||||
@ -64,6 +73,7 @@
|
|||||||
var state = await AuthenticationStateProvider.GetAuthenticationStateAsync();
|
var state = await AuthenticationStateProvider.GetAuthenticationStateAsync();
|
||||||
if (state.User.Identity?.IsAuthenticated ?? false)
|
if (state.User.Identity?.IsAuthenticated ?? false)
|
||||||
{
|
{
|
||||||
|
currentUserId = state.User.FindFirst(ClaimTypes.NameIdentifier).Value;
|
||||||
usersWithRoles = await UsersService.GetUsersWithRole();
|
usersWithRoles = await UsersService.GetUsersWithRole();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,12 +127,44 @@
|
|||||||
|
|
||||||
async Task DeleteUser(AppUserWithRole userWithRole)
|
async Task DeleteUser(AppUserWithRole userWithRole)
|
||||||
{
|
{
|
||||||
// TODO: Implement method
|
try
|
||||||
|
{
|
||||||
|
if (await DialogService.Confirm(
|
||||||
|
$"Вы уверены что хотите удалить пользователя '{userWithRole.User.UserName}'?",
|
||||||
|
"Удаление пользователя",
|
||||||
|
new ConfirmOptions()
|
||||||
|
{
|
||||||
|
OkButtonText = "Да",
|
||||||
|
CancelButtonText = "Отмена"
|
||||||
|
}) == true)
|
||||||
|
{
|
||||||
|
isLoading = true;
|
||||||
|
|
||||||
|
var result = await UsersService.DeleteUser(userWithRole.User.Id);
|
||||||
|
if (result.Succeeded)
|
||||||
|
{
|
||||||
|
await UpdateGrid();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
isLoading = false;
|
||||||
|
hasError = true;
|
||||||
|
errorMessage = string.Join(", ", result.Errors.Select(x => x.Description));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
isLoading = false;
|
||||||
|
hasError = true;
|
||||||
|
errorMessage = e.Message;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async Task UpdateGrid()
|
async Task UpdateGrid()
|
||||||
{
|
{
|
||||||
isLoading = true;
|
isLoading = true;
|
||||||
|
hasError = false;
|
||||||
|
|
||||||
usersWithRoles = await UsersService.GetUsersWithRole();
|
usersWithRoles = await UsersService.GetUsersWithRole();
|
||||||
|
|
||||||
|
|||||||
@ -88,5 +88,11 @@ namespace Hcs.WebApp.Services
|
|||||||
}
|
}
|
||||||
await transaction.CommitAsync();
|
await transaction.CommitAsync();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public async Task<IdentityResult> DeleteUser(string userId)
|
||||||
|
{
|
||||||
|
var user = await userManager.FindByIdAsync(userId);
|
||||||
|
return await userManager.DeleteAsync(user);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user