From ee7f560830a6cf81c1ffe0a22dfe9af32bd9e6c5 Mon Sep 17 00:00:00 2001 From: "John.Vaughan" Date: Wed, 14 Aug 2024 14:04:03 +0100 Subject: [PATCH 1/2] Optimises Project/GetProject --- src/BL/Models/SubmissionGetProjectModel.cs | 35 +++++++++++++++---- src/DARE-API/Controllers/ProjectController.cs | 4 ++- .../Controllers/ProjectController.cs | 8 ++--- 3 files changed, 35 insertions(+), 12 deletions(-) diff --git a/src/BL/Models/SubmissionGetProjectModel.cs b/src/BL/Models/SubmissionGetProjectModel.cs index 84a673ab8..69094794b 100644 --- a/src/BL/Models/SubmissionGetProjectModel.cs +++ b/src/BL/Models/SubmissionGetProjectModel.cs @@ -1,5 +1,6 @@ using BL.Models.Enums; using BL.Models.Helpers; +using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; @@ -27,13 +28,17 @@ public class SubmissionGetProjectModel public virtual List Tres { get; set; } + public virtual List UsersNotInProject { get; set; } + + public virtual List TresNotInProject { get; set; } + public virtual List Submissions { get; set; } public SubmissionGetProjectModel() { } - public SubmissionGetProjectModel(Project Project) + public SubmissionGetProjectModel(Project Project, DbSet UsersAll, DbSet TREsALL) { Id = Project.Id; FormData = Project.FormData; @@ -46,17 +51,35 @@ public SubmissionGetProjectModel(Project Project) SubmissionBucket = Project.SubmissionBucket; OutputBucket = Project.OutputBucket; Users = new List(); - foreach (var item in Project.Users) + UsersNotInProject = new List(); + foreach (var user in UsersAll) { - Users.Add(new UserGetProjectModel(item)); + if (Project.Users.Contains(user)) + { + Users.Add(new UserGetProjectModel(user)); + } + else + { + UsersNotInProject.Add(new UserGetProjectModel(user)); + } } + Tres = new List(); - foreach (var item in Project.Tres) + TresNotInProject = new List(); + + foreach (var tre in TREsALL) { - Tres.Add(new TreGetProjectModel(item, Id)); + if (Project.Tres.Contains(tre)) + { + Tres.Add(new TreGetProjectModel(tre, Id)); + } + else + { + TresNotInProject.Add(new TreGetProjectModel(tre, Id)); + } } - + Submissions = new List(); foreach (var item in Project.Submissions) { diff --git a/src/DARE-API/Controllers/ProjectController.cs b/src/DARE-API/Controllers/ProjectController.cs index 512789f51..90dc8b4e1 100644 --- a/src/DARE-API/Controllers/ProjectController.cs +++ b/src/DARE-API/Controllers/ProjectController.cs @@ -355,7 +355,9 @@ public ProjectController(ApplicationDbContext applicationDbContext, MinioSetting } Log.Information("{Function} Project retrieved successfully", "GetProject"); - return new SubmissionGetProjectModel(returned); + var Users = _DbContext.Users.ToList(); + _DbContext.Tres.ToList(); + return new SubmissionGetProjectModel(returned, _DbContext.Users, _DbContext.Tres); } catch (Exception ex) { diff --git a/src/DARE-FrontEnd/Controllers/ProjectController.cs b/src/DARE-FrontEnd/Controllers/ProjectController.cs index 36ed7d5cc..ed8aedea2 100644 --- a/src/DARE-FrontEnd/Controllers/ProjectController.cs +++ b/src/DARE-FrontEnd/Controllers/ProjectController.cs @@ -89,11 +89,9 @@ public async Task GetProject(int id) //Log.Error("minioEndpoint took ElapsedMilliseconds" + stopwatch.ElapsedMilliseconds); stopwatch.Stop(); var project = projectawait.Result; - var users = _clientHelper.CallAPIWithoutModel>("/api/User/GetAllUsers/").Result; - var tres = _clientHelper.CallAPIWithoutModel>("/api/Tre/GetAllTres/").Result; - - var userItems2 = users.Where(p => !project.Users.Select(x => x.Id).Contains(p.Id)).ToList(); - var treItems2 = tres.Where(p => !project.Tres.Select(x => x.Id).Contains(p.Id)).ToList(); + + var userItems2 = project.UsersNotInProject; + var treItems2 = project.TresNotInProject; var userItems = userItems2 .Select(p => new SelectListItem { Value = p.Id.ToString(), Text = p.FullName != "" ? p.FullName : p.Name }) From 2102853372c2ef54a422a341680391e8b529d5be Mon Sep 17 00:00:00 2001 From: "John.Vaughan" Date: Wed, 14 Aug 2024 14:17:33 +0100 Subject: [PATCH 2/2] fix --- src/BL/Models/SubmissionGetProjectModel.cs | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/src/BL/Models/SubmissionGetProjectModel.cs b/src/BL/Models/SubmissionGetProjectModel.cs index 69094794b..5fa271015 100644 --- a/src/BL/Models/SubmissionGetProjectModel.cs +++ b/src/BL/Models/SubmissionGetProjectModel.cs @@ -52,7 +52,9 @@ public SubmissionGetProjectModel(Project Project, DbSet UsersAll, DbSet(); UsersNotInProject = new List(); - foreach (var user in UsersAll) + + + foreach (var user in UsersAll.ToArray()) { if (Project.Users.Contains(user)) { @@ -67,8 +69,9 @@ public SubmissionGetProjectModel(Project Project, DbSet UsersAll, DbSet(); TresNotInProject = new List(); + - foreach (var tre in TREsALL) + foreach (var tre in TREsALL.ToArray()) { if (Project.Tres.Contains(tre)) {