Added server count for image overview

This commit is contained in:
Marcel Baumgartner
2023-04-25 21:55:35 +02:00
parent 60cb41dde7
commit ab21fb965c

View File

@@ -4,9 +4,12 @@
@using Microsoft.EntityFrameworkCore @using Microsoft.EntityFrameworkCore
@using Moonlight.App.Database.Entities @using Moonlight.App.Database.Entities
@using Moonlight.App.Repositories @using Moonlight.App.Repositories
@using Moonlight.App.Repositories.Servers
@using Moonlight.App.Services @using Moonlight.App.Services
@inject ImageRepository ImageRepository @inject Repository<Image> ImageRepository
@inject Repository<ImageVariable> ImageVariableRepository
@inject Repository<Server> ServerRepository
@inject SmartTranslateService SmartTranslateService @inject SmartTranslateService SmartTranslateService
<OnlyAdmin> <OnlyAdmin>
@@ -35,6 +38,16 @@
<Column TableItem="Image" Title="@(SmartTranslateService.Translate("Name"))" Field="@(x => x.Name)" Sortable="true" Filterable="true"/> <Column TableItem="Image" Title="@(SmartTranslateService.Translate("Name"))" Field="@(x => x.Name)" Sortable="true" Filterable="true"/>
<Column TableItem="Image" Title="@(SmartTranslateService.Translate("Description"))" Field="@(x => x.Description)" Sortable="true" Filterable="true"/> <Column TableItem="Image" Title="@(SmartTranslateService.Translate("Description"))" Field="@(x => x.Description)" Sortable="true" Filterable="true"/>
<Column TableItem="Image" Title="@(SmartTranslateService.Translate("Uuid"))" Field="@(x => x.Uuid)" Sortable="true" Filterable="true"/> <Column TableItem="Image" Title="@(SmartTranslateService.Translate("Uuid"))" Field="@(x => x.Uuid)" Sortable="true" Filterable="true"/>
<Column TableItem="Image" Title="@(SmartTranslateService.Translate("Servers with this image"))" Field="@(x => x.Id)" Sortable="false" Filterable="false">
<Template>
@{
var i = ServersCount.TryGetValue(context, out var value) ? value.ToString() : "N/A";
}
<span>
@(i)
</span>
</Template>
</Column>
<Column TableItem="Image" Title="" Field="@(x => x.Id)" Sortable="false" Filterable="false"> <Column TableItem="Image" Title="" Field="@(x => x.Id)" Sortable="false" Filterable="false">
<Template> <Template>
<a href="/admin/servers/images/edit/@(context.Id)"> <a href="/admin/servers/images/edit/@(context.Id)">
@@ -72,19 +85,45 @@
private Image[] Images; private Image[] Images;
private LazyLoader LazyLoader; private LazyLoader LazyLoader;
private Task Load(LazyLoader arg) private Dictionary<Image, int> ServersCount = new();
private async Task Load(LazyLoader lazyLoader)
{ {
await lazyLoader.SetText("Loading images");
Images = ImageRepository Images = ImageRepository
.Get() .Get()
.Include(x => x.DockerImages) .Include(x => x.DockerImages)
.Include(x => x.Variables) .Include(x => x.Variables)
.ToArray(); .ToArray();
return Task.CompletedTask; await lazyLoader.SetText("Counting image servers");
ServersCount.Clear();
foreach (var image in Images)
{
var c = ServerRepository
.Get()
.Include(x => x.Image)
.Count(x => x.Image.Id == image.Id);
ServersCount.Add(image, c);
}
} }
private async Task Delete(Image image) private async Task Delete(Image image)
{ {
var variables = image.Variables.ToArray();
image.Variables.Clear();
ImageRepository.Update(image);
foreach (var v in variables)
{
ImageVariableRepository.Delete(v);
}
ImageRepository.Delete(image); ImageRepository.Delete(image);
await LazyLoader.Reload(); await LazyLoader.Reload();
} }