59 lines
2.0 KiB
Plaintext
59 lines
2.0 KiB
Plaintext
@namespace Oqtane.Modules.Admin.Users
|
|
@inherits ModuleBase
|
|
@inject IUserRoleService UserRoleService
|
|
@inject IUserService UserService
|
|
|
|
@if (userroles == null)
|
|
{
|
|
<p><em>Loading...</em></p>
|
|
}
|
|
else
|
|
{
|
|
<ActionLink Action="Add" Text="Add User" />
|
|
|
|
<Pager Items="@userroles">
|
|
<Header>
|
|
<th> </th>
|
|
<th> </th>
|
|
<th> </th>
|
|
<th>Name</th>
|
|
</Header>
|
|
<Row>
|
|
<td><ActionLink Action="Edit" Parameters="@($"id=" + context.UserId.ToString())" /></td>
|
|
<td><ActionDialog Header="Delete User" Message="@("Are You Sure You Wish To Delete " + context.User.DisplayName + "?")" Action="Delete" Security="SecurityAccessLevel.Admin" Class="btn btn-danger" OnClick="@(async () => await DeleteUser(context))" /></td>
|
|
<td><ActionLink Action="Roles" Parameters="@($"id=" + context.UserId.ToString())" /></td>
|
|
<td>@context.User.DisplayName</td>
|
|
</Row>
|
|
</Pager>
|
|
}
|
|
|
|
@code {
|
|
private List<UserRole> userroles;
|
|
|
|
public override SecurityAccessLevel SecurityAccessLevel => SecurityAccessLevel.Admin;
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
{
|
|
userroles = await UserRoleService.GetUserRolesAsync(PageState.Site.SiteId);
|
|
userroles = userroles.Where(item => item.Role.Name == Constants.RegisteredRole).ToList();
|
|
}
|
|
|
|
private async Task DeleteUser(UserRole UserRole)
|
|
{
|
|
try
|
|
{
|
|
var user = await UserService.GetUserAsync(UserRole.UserId, PageState.Site.SiteId);
|
|
if (user != null)
|
|
{
|
|
await UserService.DeleteUserAsync(user.UserId);
|
|
await logger.LogInformation("User Deleted {User}", UserRole.User);
|
|
StateHasChanged();
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
await logger.LogError(ex, "Error Deleting User {User} {Error}", UserRole.User, ex.Message);
|
|
AddModuleMessage(ex.Message, MessageType.Error);
|
|
}
|
|
}
|
|
} |