moved hierarchical ordering logic to server for pages and folders
This commit is contained in:
		| @ -1,10 +1,8 @@ | ||||
| using Oqtane.Models; | ||||
| using System.Threading.Tasks; | ||||
| using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Collections.Generic; | ||||
| using Oqtane.Shared; | ||||
| using System; | ||||
| using System.Diagnostics.CodeAnalysis; | ||||
| using System.Net; | ||||
| using Oqtane.Documentation; | ||||
| @ -20,9 +18,7 @@ namespace Oqtane.Services | ||||
|  | ||||
|         public async Task<List<Folder>> GetFoldersAsync(int siteId) | ||||
|         { | ||||
|             List<Folder> folders = await GetJsonAsync<List<Folder>>($"{ApiUrl}?siteid={siteId}"); | ||||
|             folders = GetFoldersHierarchy(folders); | ||||
|             return folders; | ||||
|             return await GetJsonAsync<List<Folder>>($"{ApiUrl}?siteid={siteId}"); | ||||
|         } | ||||
|  | ||||
|         public async Task<Folder> GetFolderAsync(int folderId) | ||||
| @ -58,48 +54,5 @@ namespace Oqtane.Services | ||||
|         { | ||||
|             await DeleteAsync($"{ApiUrl}/{folderId}"); | ||||
|         } | ||||
|  | ||||
|         private static List<Folder> GetFoldersHierarchy(List<Folder> folders) | ||||
|         { | ||||
|             List<Folder> hierarchy = new List<Folder>(); | ||||
|             Action<List<Folder>, Folder> getPath = null; | ||||
|             var folders1 = folders; | ||||
|             getPath = (folderList, folder) => | ||||
|             { | ||||
|                 IEnumerable<Folder> children; | ||||
|                 int level; | ||||
|                 if (folder == null) | ||||
|                 { | ||||
|                     level = -1; | ||||
|                     children = folders1.Where(item => item.ParentId == null); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     level = folder.Level; | ||||
|                     children = folders1.Where(item => item.ParentId == folder.FolderId); | ||||
|                 } | ||||
|  | ||||
|                 foreach (Folder child in children) | ||||
|                 { | ||||
|                     child.Level = level + 1; | ||||
|                     child.HasChildren = folders1.Any(item => item.ParentId == child.FolderId); | ||||
|                     hierarchy.Add(child); | ||||
|                     if (getPath != null) getPath(folderList, child); | ||||
|                 } | ||||
|             }; | ||||
|             folders = folders.OrderBy(item => item.Order).ToList(); | ||||
|             getPath(folders, null); | ||||
|  | ||||
|             // add any non-hierarchical items to the end of the list | ||||
|             foreach (Folder folder in folders) | ||||
|             { | ||||
|                 if (hierarchy.Find(item => item.FolderId == folder.FolderId) == null) | ||||
|                 { | ||||
|                     hierarchy.Add(folder); | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             return hierarchy; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -1,10 +1,8 @@ | ||||
| using Oqtane.Models; | ||||
| using System.Threading.Tasks; | ||||
| using System.Linq; | ||||
| using System.Net.Http; | ||||
| using System.Collections.Generic; | ||||
| using Oqtane.Shared; | ||||
| using System; | ||||
| using System.Net; | ||||
| using Oqtane.Documentation; | ||||
|  | ||||
| @ -19,9 +17,7 @@ namespace Oqtane.Services | ||||
|  | ||||
|         public async Task<List<Page>> GetPagesAsync(int siteId) | ||||
|         { | ||||
|             List<Page> pages = await GetJsonAsync<List<Page>>($"{Apiurl}?siteid={siteId}"); | ||||
|             pages = GetPagesHierarchy(pages); | ||||
|             return pages; | ||||
|             return await GetJsonAsync<List<Page>>($"{Apiurl}?siteid={siteId}"); | ||||
|         } | ||||
|  | ||||
|         public async Task<Page> GetPageAsync(int pageId) | ||||
| @ -73,45 +69,5 @@ namespace Oqtane.Services | ||||
|         { | ||||
|             await DeleteAsync($"{Apiurl}/{pageId}"); | ||||
|         } | ||||
|  | ||||
|         private static List<Page> GetPagesHierarchy(List<Page> pages) | ||||
|         { | ||||
|             List<Page> hierarchy = new List<Page>(); | ||||
|             Action<List<Page>, Page> getPath = null; | ||||
|             getPath = (pageList, page) => | ||||
|             { | ||||
|                 IEnumerable<Page> children; | ||||
|                 int level; | ||||
|                 if (page == null) | ||||
|                 { | ||||
|                     level = -1; | ||||
|                     children = pages.Where(item => item.ParentId == null); | ||||
|                 } | ||||
|                 else | ||||
|                 { | ||||
|                     level = page.Level; | ||||
|                     children = pages.Where(item => item.ParentId == page.PageId); | ||||
|                 } | ||||
|                 foreach (Page child in children) | ||||
|                 { | ||||
|                     child.Level = level + 1; | ||||
|                     child.HasChildren = pages.Any(item => item.ParentId == child.PageId); | ||||
|                     hierarchy.Add(child); | ||||
|                     getPath(pageList, child); | ||||
|                 } | ||||
|             }; | ||||
|             pages = pages.OrderBy(item => item.Order).ToList(); | ||||
|             getPath(pages, null); | ||||
|  | ||||
|             // add any non-hierarchical items to the end of the list | ||||
|             foreach (Page page in pages) | ||||
|             { | ||||
|                 if (hierarchy.Find(item => item.PageId == page.PageId) == null) | ||||
|                 { | ||||
|                     hierarchy.Add(page); | ||||
|                 } | ||||
|             } | ||||
|             return hierarchy; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 Shaun Walker
					Shaun Walker