@using LucideBlazor @using Microsoft.AspNetCore.Authorization @using Microsoft.AspNetCore.Components.Authorization @using Moonlight.Frontend.UI.Admin.Modals @using Moonlight.Shared @using Moonlight.Shared.Http.Requests @using Moonlight.Shared.Http.Responses @using Moonlight.Shared.Http.Responses.Admin @using ShadcnBlazor.DataGrids @using ShadcnBlazor.Buttons @using ShadcnBlazor.Dropdowns @using ShadcnBlazor.Extras.AlertDialogs @using ShadcnBlazor.Extras.Dialogs @using ShadcnBlazor.Extras.Toasts @using ShadcnBlazor.Tabels @inject HttpClient HttpClient @inject DialogService DialogService @inject ToastService ToastService @inject AlertDialogService AlertDialogService @inject IAuthorizationService AuthorizationService

Roles

Manage roles, their members and permissions
Name @context.Name
Members Edit Delete
@code { [CascadingParameter] public Task AuthState { get; set; } private DataGrid Grid; private AuthorizationResult MembersAccess; private AuthorizationResult EditAccess; private AuthorizationResult DeleteAccess; private AuthorizationResult CreateAccess; protected override async Task OnInitializedAsync() { var authState = await AuthState; MembersAccess = await AuthorizationService.AuthorizeAsync(authState.User, Permissions.Roles.Members); EditAccess = await AuthorizationService.AuthorizeAsync(authState.User, Permissions.Roles.Edit); DeleteAccess = await AuthorizationService.AuthorizeAsync(authState.User, Permissions.Roles.Delete); CreateAccess = await AuthorizationService.AuthorizeAsync(authState.User, Permissions.Roles.Create); } private async Task> LoadAsync(DataGridRequest request) { var query = $"?startIndex={request.StartIndex}&length={request.Length}"; var filterOptions = request.Filters.Count > 0 ? new FilterOptions(request.Filters) : null; var response = await HttpClient.GetFromJsonAsync>( $"api/admin/roles{query}&filterOptions={filterOptions}", Constants.SerializerOptions ); return new DataGridResponse(response!.Data, response.TotalLength); } private async Task CreateAsync() { await DialogService.LaunchAsync(parameters => { parameters[nameof(CreateRoleDialog.OnSubmit)] = async Task () => { await Grid.RefreshAsync(); }; }); } private async Task EditAsync(RoleDto role) { await DialogService.LaunchAsync(parameters => { parameters[nameof(UpdateRoleDialog.Role)] = role; parameters[nameof(UpdateRoleDialog.OnSubmit)] = async Task () => { await Grid.RefreshAsync(); }; }); } private async Task MembersAsync(RoleDto role) { if (!MembersAccess.Succeeded) { await ToastService.ErrorAsync("Permission denied", "You dont have the required permission to manage members"); return; } await DialogService.LaunchAsync(parameters => { parameters[nameof(ManageRoleMembersDialog.Role)] = role; }, model => { model.ClassName = "sm:max-w-xl"; }); } private async Task DeleteAsync(RoleDto role) { await AlertDialogService.ConfirmDangerAsync( $"Deletion of role {role.Name}", $"Do you really want to delete the role {role.Name} with {role.MemberCount} members? This action cannot be undone", async () => { var response = await HttpClient.DeleteAsync($"api/admin/roles/{role.Id}"); response.EnsureSuccessStatusCode(); await ToastService.SuccessAsync("User deletion", $"Successfully deleted role {role.Name}"); await Grid.RefreshAsync(); } ); } }