@using LucideBlazor @using Moonlight.Frontend.UI.Admin.Modals @using ShadcnBlazor.Buttons @using ShadcnBlazor.DataGrids @using ShadcnBlazor.Dropdowns @using ShadcnBlazor.Extras.AlertDialogs @using ShadcnBlazor.Extras.Toasts @using ShadcnBlazor.Tabels @using Moonlight.Shared.Http.Requests @using Moonlight.Shared.Http.Requests.Users @using Moonlight.Shared.Http.Responses @using Moonlight.Shared.Http.Responses.Users @using ShadcnBlazor.Extras.Dialogs @inject HttpClient HttpClient @inject AlertDialogService AlertDialogService @inject DialogService DialogService @inject ToastService ToastService

Users

Manage users registered in your instance
Edit Delete
@code { private DataGrid Grid; 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/users{query}&filterOptions={filterOptions}", Constants.SerializerOptions ); return new DataGridResponse(response!.Data, response.TotalLength); } private async Task CreateAsync() { await DialogService.LaunchAsync(parameters => { parameters[nameof(CreateUserDialog.OnSubmit)] = async (CreateUserDto dto) => { await HttpClient.PostAsJsonAsync( "/api/users", dto, Constants.SerializerOptions ); await ToastService.SuccessAsync( "User creation", $"Successfully created user {dto.Username}" ); await Grid.RefreshAsync(); }; }); } private async Task EditAsync(UserDto user) { await DialogService.LaunchAsync(parameters => { parameters[nameof(UpdateUserDialog.User)] = user; parameters[nameof(CreateUserDialog.OnSubmit)] = async (UpdateUserDto dto) => { await HttpClient.PatchAsJsonAsync( $"/api/users/{user.Id}", dto ); await ToastService.SuccessAsync( "User update", $"Successfully updated user {dto.Username}" ); await Grid.RefreshAsync(); }; }); } private async Task DeleteAsync(UserDto user) { await AlertDialogService.ConfirmDangerAsync( $"Deletion of user {user.Username}", "Do you really want to delete this user? This action cannot be undone", async () => { await HttpClient.DeleteAsync($"api/users/{user.Id}"); await ToastService.SuccessAsync("User deletion", $"Successfully deleted user {user.Username}"); await Grid.RefreshAsync(); } ); } }