فهرست منبع

Added user edit form. Fixed edit link

Marcel Baumgartner 2 سال پیش
والد
کامیت
69cfeace82
3فایلهای تغییر یافته به همراه197 افزوده شده و 1 حذف شده
  1. 187 0
      Moonlight/Shared/Views/Admin/Users/Edit.razor
  2. 1 1
      Moonlight/Shared/Views/Admin/Users/Index.razor
  3. 9 0
      Moonlight/resources/lang/de_de.lang

+ 187 - 0
Moonlight/Shared/Views/Admin/Users/Edit.razor

@@ -0,0 +1,187 @@
+@page "/admin/users/edit/{Id:int}"
+@using Moonlight.App.Repositories
+@using Moonlight.App.Database.Entities
+@using Moonlight.App.Models.Misc
+@using Moonlight.App.Services
+@using Moonlight.App.Services.Interop
+@using Moonlight.App.Services.Sessions
+
+@inject UserRepository UserRepository
+@inject SessionService SessionService
+@inject ToastService ToastService
+@inject SmartTranslateService SmartTranslateService
+
+<OnlyAdmin>
+    <LazyLoader Load="Load">
+        @if (User == null)
+        {
+            <div class="alert alert-danger">
+                <TL>No user with this id found</TL>
+            </div>
+        }
+        else
+        {
+            <div class="card">
+                <div class="card-header border-0 py-0">
+                    <h3 class="card-title align-items-start flex-column">
+                        <span class="card-label fw-bold fs-3">
+                            <TL>Manage user </TL> <span class="text-primary">@(User.Email)</span>
+                        </span>
+                    </h3>
+                </div>
+            </div>
+
+            <div class="mt-5 row">
+                <div class="col-xl-6 mb-5 mb-xl-10">
+                    <div class="card card-body p-10">
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>First name</TL>
+                            </label>
+                            <input @bind="User.FirstName" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Last name</TL>
+                            </label>
+                            <input @bind="User.LastName" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Email</TL>
+                            </label>
+                            <input @bind="User.Email" type="email" class="form-control">
+                        </div>
+                    </div>
+                    <div class="mt-5 card card-body p-10">
+                        <div class="input-group">
+                            <select @bind="User.Status" class="form-select">
+                                @foreach (var status in (UserStatus[])Enum.GetValues(typeof(UserStatus)))
+                                {
+                                    if (User.Status == status)
+                                    {
+                                        <option value="@(status)" selected="">@(status)</option>
+                                    }
+                                    else
+                                    {
+                                        <option value="@(status)">@(status)</option>
+                                    }
+                                }
+                            </select>
+                            <WButton Text="@(SmartTranslateService.Translate("Change"))"
+                                     WorkingText="@(SmartTranslateService.Translate("Reloading"))"
+                                     CssClasses="btn-primary"
+                                     OnClick="UpdateStatus">
+                            </WButton>
+                        </div>
+                    </div>
+                    <div class="mt-5 card card-body p-10">
+                                    <div class="d-flex justify-content-end">
+                                        <a href="/admin/users" class="btn btn-danger me-3">
+                                            <TL>Cancel</TL>
+                                        </a>
+                                        <WButton Text="@(SmartTranslateService.Translate("Update"))"
+                                                 WorkingText="@(SmartTranslateService.Translate("Updating"))"
+                                                 CssClasses="btn-success"
+                                                 OnClick="Update">
+                                        </WButton>
+                                    </div>
+                                </div>
+                </div>
+                <div class="col-xl-6 mb-5 mb-xl-10">
+                    <div class="card card-body p-10">
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Address</TL>
+                            </label>
+                            <input @bind="User.Address" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>City</TL>
+                            </label>
+                            <input @bind="User.City" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>State</TL>
+                            </label>
+                            <input @bind="User.State" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Country</TL>
+                            </label>
+                            <input @bind="User.Country" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <input @bind="User.TotpEnabled" type="checkbox" class="form-check-input">
+                            <label class="form-label">
+                                <TL>Totp</TL>
+                            </label>
+                        </div>
+                        <div class="mb-10">
+                            <input @bind="User.Admin" type="checkbox" class="form-check-input">
+                            <label class="form-label">
+                                <TL>Admin</TL>
+                            </label>
+                        </div>
+                    </div>
+                    <div class="mt-5 card card-body p-10">
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Discord id</TL>
+                            </label>
+                            <input @bind="User.DiscordId" type="number" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Discord username</TL>
+                            </label>
+                            <input @bind="User.DiscordUsername" type="text" class="form-control">
+                        </div>
+                        <div class="mb-10">
+                            <label class="form-label">
+                                <TL>Discord discriminator</TL>
+                            </label>
+                            <input @bind="User.DiscordDiscriminator" type="text" class="form-control">
+                        </div>
+                    </div>
+                </div>
+            </div>
+        }
+    </LazyLoader>
+</OnlyAdmin>
+
+@code
+{
+    [Parameter]
+    public int Id { get; set; }
+
+    private User? User;
+
+    private Task Load(LazyLoader arg)
+    {
+        User = UserRepository.Get().FirstOrDefault(x => x.Id == Id);
+
+        return Task.CompletedTask;
+    }
+
+    private async Task UpdateStatus()
+    {
+        var user = UserRepository.Get().FirstOrDefault(x => x.Id == User!.Id)!;
+        user.Status = User!.Status;
+        UserRepository.Update(user);
+
+        SessionService.ReloadUserSessions(User);
+
+        await ToastService.Success(SmartTranslateService.Translate("Successfully updated user"));
+    }
+
+    private async Task Update()
+    {
+        UserRepository.Update(User!);
+
+        await ToastService.Success(SmartTranslateService.Translate("Successfully updated user"));
+    }
+}

+ 1 - 1
Moonlight/Shared/Views/Admin/Users/Index.razor

@@ -41,7 +41,7 @@
                         <Column TableItem="User" Title="@(SmartTranslateService.Translate("Created at"))" Field="@(x => x.CreatedAt)" Sortable="true" Filterable="true"/>
                         <Column TableItem="User" Title="@(SmartTranslateService.Translate("Created at"))" Field="@(x => x.CreatedAt)" Sortable="true" Filterable="true"/>
                         <Column TableItem="User" Title="@(SmartTranslateService.Translate("Manage"))" Field="@(x => x.Id)" Sortable="false" Filterable="false">
                         <Column TableItem="User" Title="@(SmartTranslateService.Translate("Manage"))" Field="@(x => x.Id)" Sortable="false" Filterable="false">
                             <Template>
                             <Template>
-                                <a href="/admin/users/@(context.Id)/edit">
+                                <a href="/admin/users/edit/@(context.Id)/">
                                     <TL>Manage</TL>
                                     <TL>Manage</TL>
                                 </a>
                                 </a>
                             </Template>
                             </Template>

+ 9 - 0
Moonlight/resources/lang/de_de.lang

@@ -384,3 +384,12 @@ Change power state for;Change power state for
 to;to
 to;to
 Stop all servers;Stop all servers
 Stop all servers;Stop all servers
 Do you really want to stop all running servers?;Do you really want to stop all running servers?
 Do you really want to stop all running servers?;Do you really want to stop all running servers?
+Manage ;Manage 
+Manage user ;Manage user 
+Reloading;Reloading
+Update;Update
+Updating;Updating
+Successfully updated user;Successfully updated user
+Discord id;Discord id
+Discord username;Discord username
+Discord discriminator;Discord discriminator