improve performance of alias handling and allow aliases to be an unlimited number of subfolders in depth
This commit is contained in:
		| @ -43,7 +43,7 @@ | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             [Module]Service = new [Module]Service(http, sitestate, NavigationManager); | ||||
|             [Module]Service = new [Module]Service(http, sitestate); | ||||
|             if (PageState.Action == "Edit") | ||||
|             { | ||||
|                 _id = Int32.Parse(PageState.QueryString["id"]); | ||||
|  | ||||
| @ -78,7 +78,7 @@ else | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             [Module]Service = new [Module]Service(http, sitestate, NavigationManager); | ||||
|             [Module]Service = new [Module]Service(http, sitestate); | ||||
|             _[Module]s = await [Module]Service.Get[Module]sAsync(ModuleState.ModuleId); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|  | ||||
| @ -2,7 +2,6 @@ using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Threading.Tasks; | ||||
| using Microsoft.AspNetCore.Components; | ||||
| using Oqtane.Modules; | ||||
| using Oqtane.Services; | ||||
| using Oqtane.Shared; | ||||
| @ -12,44 +11,39 @@ namespace [Owner].[Module]s.Services | ||||
| { | ||||
|     public class [Module]Service : ServiceBase, I[Module]Service, IService | ||||
|     { | ||||
|         private readonly NavigationManager _navigationManager; | ||||
|         private readonly SiteState _siteState; | ||||
|  | ||||
|         public [Module]Service(HttpClient http, SiteState siteState, NavigationManager navigationManager) : base(http) | ||||
|         public [Module]Service(HttpClient http, SiteState siteState) : base(http) | ||||
|         { | ||||
|             _siteState = siteState; | ||||
|             _navigationManager = navigationManager; | ||||
|         } | ||||
|  | ||||
|          private string Apiurl | ||||
|         { | ||||
|             get { return CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "[Module]"); } | ||||
|         } | ||||
|          private string Apiurl=> CreateApiUrl(_siteState.Alias, "[Module]"); | ||||
|  | ||||
|         public async Task<List<[Module]>> Get[Module]sAsync(int ModuleId) | ||||
|         { | ||||
|             List<[Module]> [Module]s = await GetJsonAsync<List<[Module]>>(Apiurl + "?moduleid=" + ModuleId.ToString()); | ||||
|             List<[Module]> [Module]s = await GetJsonAsync<List<[Module]>>($"{Apiurl}?moduleid={ModuleId}"); | ||||
|             return [Module]s.OrderBy(item => item.Name).ToList(); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Get[Module]Async(int [Module]Id) | ||||
|         { | ||||
|             return await GetJsonAsync<[Module]>(Apiurl + "/" + [Module]Id.ToString()); | ||||
|             return await GetJsonAsync<[Module]>($"{Apiurl}/{[Module]Id}"); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Add[Module]Async([Module] [Module]) | ||||
|         { | ||||
|             return await PostJsonAsync<[Module]>(Apiurl + "?entityid=" + [Module].ModuleId, [Module]); | ||||
|             return await PostJsonAsync<[Module]>($"{Apiurl}?entityid={[Module].ModuleId}", [Module]); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Update[Module]Async([Module] [Module]) | ||||
|         { | ||||
|             return await PutJsonAsync<[Module]>(Apiurl + "/" + [Module].[Module]Id + "?entityid=" + [Module].ModuleId, [Module]); | ||||
|             return await PutJsonAsync<[Module]>($"{Apiurl}/{[Module].[Module]Id}?entityid={[Module].ModuleId}", [Module]); | ||||
|         } | ||||
|  | ||||
|         public async Task Delete[Module]Async(int [Module]Id) | ||||
|         { | ||||
|             await DeleteAsync(Apiurl + "/" + [Module]Id.ToString()); | ||||
|             await DeleteAsync($"{Apiurl}/{[Module]Id}"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -43,7 +43,7 @@ | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             [Module]Service = new [Module]Service(http, sitestate, NavigationManager); | ||||
|             [Module]Service = new [Module]Service(http, sitestate); | ||||
|             if (PageState.Action == "Edit") | ||||
|             { | ||||
|                 _id = Int32.Parse(PageState.QueryString["id"]); | ||||
|  | ||||
| @ -69,7 +69,7 @@ else | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             [Module]Service = new [Module]Service(http, sitestate, NavigationManager); | ||||
|             [Module]Service = new [Module]Service(http, sitestate); | ||||
|             _[Module]s = await [Module]Service.Get[Module]sAsync(ModuleState.ModuleId); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
|  | ||||
| @ -2,7 +2,6 @@ using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Threading.Tasks; | ||||
| using Microsoft.AspNetCore.Components; | ||||
| using Oqtane.Modules; | ||||
| using Oqtane.Services; | ||||
| using Oqtane.Shared; | ||||
| @ -12,44 +11,39 @@ namespace [Owner].[Module]s.Services | ||||
| { | ||||
|     public class [Module]Service : ServiceBase, I[Module]Service, IService | ||||
|     { | ||||
|         private readonly NavigationManager _navigationManager; | ||||
|         private readonly SiteState _siteState; | ||||
|  | ||||
|         public [Module]Service(HttpClient http, SiteState siteState, NavigationManager navigationManager) : base(http) | ||||
|         public [Module]Service(HttpClient http, SiteState siteState) : base(http) | ||||
|         { | ||||
|             _siteState = siteState; | ||||
|             _navigationManager = navigationManager; | ||||
|         } | ||||
|  | ||||
|          private string Apiurl | ||||
|         { | ||||
|             get { return CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "[Module]"); } | ||||
|         } | ||||
|          private string Apiurl=> CreateApiUrl(_siteState.Alias, "[Module]"); | ||||
|  | ||||
|         public async Task<List<[Module]>> Get[Module]sAsync(int ModuleId) | ||||
|         { | ||||
|             List<[Module]> [Module]s = await GetJsonAsync<List<[Module]>>(Apiurl + "?moduleid=" + ModuleId.ToString()); | ||||
|             List<[Module]> [Module]s = await GetJsonAsync<List<[Module]>>($"{Apiurl}?moduleid={ModuleId}"); | ||||
|             return [Module]s.OrderBy(item => item.Name).ToList(); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Get[Module]Async(int [Module]Id) | ||||
|         { | ||||
|             return await GetJsonAsync<[Module]>(Apiurl + "/" + [Module]Id.ToString()); | ||||
|             return await GetJsonAsync<[Module]>($"{Apiurl}/{[Module]Id}"); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Add[Module]Async([Module] [Module]) | ||||
|         { | ||||
|             return await PostJsonAsync<[Module]>(Apiurl + "?entityid=" + [Module].ModuleId, [Module]); | ||||
|             return await PostJsonAsync<[Module]>($"{Apiurl}?entityid={[Module].ModuleId}", [Module]); | ||||
|         } | ||||
|  | ||||
|         public async Task<[Module]> Update[Module]Async([Module] [Module]) | ||||
|         { | ||||
|             return await PutJsonAsync<[Module]>(Apiurl + "/" + [Module].[Module]Id + "?entityid=" + [Module].ModuleId, [Module]); | ||||
|             return await PutJsonAsync<[Module]>($"{Apiurl}/{[Module].[Module]Id}?entityid={[Module].ModuleId}", [Module]); | ||||
|         } | ||||
|  | ||||
|         public async Task Delete[Module]Async(int [Module]Id) | ||||
|         { | ||||
|             await DeleteAsync(Apiurl + "/" + [Module]Id.ToString()); | ||||
|             await DeleteAsync($"{Apiurl}/{[Module]Id}"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -251,7 +251,7 @@ | ||||
|         { | ||||
|             _themeList = await ThemeService.GetThemesAsync(); | ||||
|             _aliasList = await AliasService.GetAliasesAsync(); | ||||
|             Site site = await SiteService.GetSiteAsync(PageState.Site.SiteId, PageState.Alias); | ||||
|             Site site = await SiteService.GetSiteAsync(PageState.Site.SiteId); | ||||
|             if (site != null) | ||||
|             { | ||||
|                 _name = site.Name; | ||||
| @ -364,7 +364,7 @@ | ||||
|  | ||||
|                 if (unique) | ||||
|                 { | ||||
|                     var site = await SiteService.GetSiteAsync(PageState.Site.SiteId, PageState.Alias); | ||||
|                     var site = await SiteService.GetSiteAsync(PageState.Site.SiteId); | ||||
|                     if (site != null) | ||||
|                     { | ||||
|                         site.Name = _name; | ||||
| @ -395,7 +395,7 @@ | ||||
|                             site.PwaSplashIconFileId = pwasplashiconfileid; | ||||
|                         } | ||||
|  | ||||
|                         site = await SiteService.UpdateSiteAsync(site, PageState.Alias); | ||||
|                         site = await SiteService.UpdateSiteAsync(site); | ||||
|  | ||||
|                         _urls = _urls.Replace("\n", ","); | ||||
|                         var names = _urls.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries); | ||||
|  | ||||
| @ -134,18 +134,19 @@ | ||||
|             _aliasList = await AliasService.GetAliasesAsync(); | ||||
|  | ||||
|             _alias = _aliasList.Find(item => item.AliasId == Int32.Parse(PageState.QueryString["id"])); | ||||
|             var site = await SiteService.GetSiteAsync(_alias.SiteId, _alias); | ||||
|             SiteService.SetAlias(_alias); | ||||
|             var site = await SiteService.GetSiteAsync(_alias.SiteId); | ||||
|             if (site != null) | ||||
|             { | ||||
|                 _name = site.Name; | ||||
|                 _tenantList = await TenantService.GetTenantsAsync(); | ||||
|                 _tenant = _tenantList.Find(item => item.TenantId == site.TenantId).Name; | ||||
|                  | ||||
|  | ||||
|                 foreach (Alias alias in _aliasList.Where(item => item.SiteId == site.SiteId && item.TenantId == site.TenantId).ToList()) | ||||
|                 { | ||||
|                     _urls += alias.Name + "\n"; | ||||
|                 } | ||||
|                  | ||||
|  | ||||
|                 _themetype = site.DefaultThemeType; | ||||
|                 _panelayouts = ThemeService.GetPaneLayoutTypes(_themeList, _themetype); | ||||
|                 _layouttype = site.DefaultLayoutType; | ||||
| @ -182,7 +183,7 @@ | ||||
|             { | ||||
|                 _panelayouts = new Dictionary<string, string>(); | ||||
|             } | ||||
|              | ||||
|  | ||||
|             StateHasChanged(); | ||||
|         } | ||||
|         catch (Exception ex) | ||||
| @ -206,10 +207,11 @@ | ||||
|                         unique = false; | ||||
|                     } | ||||
|                 } | ||||
|                  | ||||
|  | ||||
|                 if (unique) | ||||
|                 { | ||||
|                     var site = await SiteService.GetSiteAsync(_alias.SiteId, _alias); | ||||
|                     SiteService.SetAlias(_alias); | ||||
|                     var site = await SiteService.GetSiteAsync(_alias.SiteId); | ||||
|                     if (site != null) | ||||
|                     { | ||||
|                         site.Name = _name; | ||||
| @ -219,11 +221,11 @@ | ||||
|                         site.DefaultContainerType = _containertype; | ||||
|                         site.IsDeleted = (_isdeleted == null || Boolean.Parse(_isdeleted)); | ||||
|  | ||||
|                         site = await SiteService.UpdateSiteAsync(site, _alias); | ||||
|                         site = await SiteService.UpdateSiteAsync(site); | ||||
|  | ||||
|                         _urls = _urls.Replace("\n", ","); | ||||
|                         var names = _urls.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries); | ||||
|                          | ||||
|  | ||||
|                         foreach (Alias alias in _aliasList.Where(item => item.SiteId == site.SiteId && item.TenantId == site.TenantId).ToList()) | ||||
|                         { | ||||
|                             if (!names.Contains(alias.Name)) | ||||
| @ -231,7 +233,7 @@ | ||||
|                                 await AliasService.DeleteAliasAsync(alias.AliasId); | ||||
|                             } | ||||
|                         } | ||||
|                          | ||||
|  | ||||
|                         foreach (string name in names) | ||||
|                         { | ||||
|                             if (!_aliasList.Exists(item => item.Name == name)) | ||||
|  | ||||
| @ -54,7 +54,8 @@ else | ||||
|         { | ||||
|             if (alias.SiteId != PageState.Site.SiteId || alias.TenantId != PageState.Site.TenantId) | ||||
|             { | ||||
|                 await SiteService.DeleteSiteAsync(alias.SiteId, alias); | ||||
|                 SiteService.SetAlias(alias); | ||||
|                 await SiteService.DeleteSiteAsync(alias.SiteId); | ||||
|                 await Log(alias, LogLevel.Information, "", null, "Site Deleted {SiteId}", alias.SiteId); | ||||
|                  | ||||
|                 var aliases = await AliasService.GetAliasesAsync(); | ||||
|  | ||||
| @ -16,7 +16,7 @@ | ||||
|         <RichTextEditor @ref="@RichTextEditorHtml"> | ||||
|             <ToolbarContent> | ||||
|                 <select class="ql-header"> | ||||
|                     <option selected=string.Empty></option> | ||||
|                     <option selected=""></option> | ||||
|                     <option value="1"></option> | ||||
|                     <option value="2"></option> | ||||
|                     <option value="3"></option> | ||||
| @ -123,7 +123,7 @@ | ||||
|  | ||||
|     private async Task LoadText() | ||||
|     { | ||||
|         var htmltextservice = new HtmlTextService(http, sitestate, NavigationManager); | ||||
|         var htmltextservice = new HtmlTextService(http, sitestate); | ||||
|         var htmltext = await htmltextservice.GetHtmlTextAsync(ModuleState.ModuleId); | ||||
|         if (htmltext != null) | ||||
|         { | ||||
| @ -166,7 +166,7 @@ | ||||
|  | ||||
|         try | ||||
|         { | ||||
|             var htmltextservice = new HtmlTextService(http, sitestate, NavigationManager); | ||||
|             var htmltextservice = new HtmlTextService(http, sitestate); | ||||
|             var htmltext = await htmltextservice.GetHtmlTextAsync(ModuleState.ModuleId); | ||||
|             if (htmltext != null) | ||||
|             { | ||||
|  | ||||
| @ -25,7 +25,7 @@ | ||||
|     { | ||||
|         try | ||||
|         { | ||||
|             var htmltextservice = new HtmlTextService(http, sitestate, NavigationManager); | ||||
|             var htmltextservice = new HtmlTextService(http, sitestate); | ||||
|             var htmltext = await htmltextservice.GetHtmlTextAsync(ModuleState.ModuleId); | ||||
|             if (htmltext != null) | ||||
|             { | ||||
|  | ||||
| @ -2,7 +2,6 @@ using System.Collections.Generic; | ||||
| using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Threading.Tasks; | ||||
| using Microsoft.AspNetCore.Components; | ||||
| using Oqtane.Modules.HtmlText.Models; | ||||
| using Oqtane.Services; | ||||
| using Oqtane.Shared; | ||||
| @ -10,52 +9,35 @@ using Oqtane.Shared; | ||||
| namespace Oqtane.Modules.HtmlText.Services | ||||
| { | ||||
|     public class HtmlTextService : ServiceBase, IHtmlTextService | ||||
|     { | ||||
|          | ||||
|         private readonly NavigationManager _navigationManager; | ||||
|     {         | ||||
|         private readonly SiteState _siteState; | ||||
|  | ||||
|         public HtmlTextService(HttpClient http, SiteState siteState, NavigationManager navigationManager) : base(http) | ||||
|         public HtmlTextService(HttpClient http, SiteState siteState) : base(http) | ||||
|         { | ||||
|              | ||||
|             _siteState = siteState; | ||||
|             _navigationManager = navigationManager; | ||||
|         } | ||||
|  | ||||
|         private string ApiUrl => CreateApiUrl(_siteState.Alias, _navigationManager.Uri, "HtmlText"); | ||||
|         private string ApiUrl => CreateApiUrl(_siteState.Alias, "HtmlText"); | ||||
|  | ||||
|         public async Task<HtmlTextInfo> GetHtmlTextAsync(int moduleId) | ||||
|         { | ||||
|             HtmlTextInfo htmlText; | ||||
|             try | ||||
|             { | ||||
|                 //because GetJsonAsync() returns an error if no content exists for the ModuleId ( https://github.com/aspnet/AspNetCore/issues/14041 ) | ||||
|                 //null value is transfered as empty list | ||||
|                 var htmlTextList = await GetJsonAsync<List<HtmlTextInfo>>(ApiUrl + "/" + moduleId + "?entityid=" + moduleId); | ||||
|                 htmlText = htmlTextList.FirstOrDefault(); | ||||
|             } | ||||
|             catch | ||||
|             { | ||||
|                 htmlText = null; | ||||
|             } | ||||
|  | ||||
|             return htmlText; | ||||
|             var htmltext = await GetJsonAsync<List<HtmlTextInfo>>($"{ApiUrl}/{moduleId}?entityid={moduleId}"); | ||||
|             return htmltext.FirstOrDefault(); | ||||
|         } | ||||
|  | ||||
|         public async Task AddHtmlTextAsync(HtmlTextInfo htmlText) | ||||
|         { | ||||
|             await PostJsonAsync(ApiUrl + "?entityid=" + htmlText.ModuleId, htmlText); | ||||
|             await PostJsonAsync($"{ApiUrl}?entityid={htmlText.ModuleId}", htmlText); | ||||
|         } | ||||
|  | ||||
|         public async Task UpdateHtmlTextAsync(HtmlTextInfo htmlText) | ||||
|         { | ||||
|             await PutJsonAsync(ApiUrl + "/" + htmlText.HtmlTextId + "?entityid=" + htmlText.ModuleId, htmlText); | ||||
|             await PutJsonAsync($"{ApiUrl}/{htmlText.HtmlTextId}?entityid={htmlText.ModuleId}", htmlText); | ||||
|         } | ||||
|  | ||||
|  | ||||
|         public async Task DeleteHtmlTextAsync(int moduleId) | ||||
|         { | ||||
|             await DeleteAsync(ApiUrl + "/" + moduleId + "?entityid=" + moduleId); | ||||
|             await DeleteAsync($"{ApiUrl}/{moduleId}?entityid={moduleId}"); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -87,7 +87,7 @@ namespace Oqtane.Modules | ||||
|  | ||||
|         public string ContentUrl(int fileid) | ||||
|         { | ||||
|             return Utilities.ContentUrl(PageState.Alias.Path, fileid); | ||||
|             return Utilities.ContentUrl(PageState.Alias, fileid); | ||||
|         } | ||||
|  | ||||
|         // user feedback methods | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker