Improved RecycleBin with PageModules

This commit is contained in:
Emanuele Filardo 2019-10-20 01:23:24 +02:00
parent e01db29354
commit ee3834b52a
4 changed files with 134 additions and 33 deletions

View File

@ -2,43 +2,100 @@
@inherits ModuleBase @inherits ModuleBase
@inject NavigationManager NavigationManager @inject NavigationManager NavigationManager
@inject IPageModuleService PageModuleService @inject IPageModuleService PageModuleService
@inject IModuleService ModuleService
@inject IPageService PageService @inject IPageService PageService
@*Add TabControl with Pages and Modules tabs*@ <TabControl>
<h3>Pages</h3> <TabPage Text="Pages">
@if (pageModules.Count == 0) @if (pages.Count == 0)
{ {
<br/>
<p>No deleted pages</p> <p>No deleted pages</p>
} }
else else
{ {
<Pager Items="@pageModules"> <Pager Items="@pages">
<Header> <Header>
<th>Name</th> <th>Name</th>
<th>Deletion audit</th> <th>Deletion Audit</th>
<th>&nbsp;</th> <th>&nbsp;</th>
<th>&nbsp;</th> <th>&nbsp;</th>
</Header> </Header>
<Row> <Row>
<td>@context.Name</td> <td>@context.Name</td>
<td>@context.DeletedBy - @context.DeletedOn</td> <td>@context.DeletedBy - @context.DeletedOn</td>
<td><button @onclick="@(() => Restore(context))" class="btn btn-info" title="Restore">Restore</button></td> <td><button @onclick="@(() => RestorePage(context))" class="btn btn-info" title="Restore">Restore</button></td>
<td><button @onclick="@(() => Delete(context.PageId))" class="btn btn-danger">Delete</button></td> <td><button @onclick="@(() => DeletePage(context.PageId))" class="btn btn-danger">Delete</button></td>
</Row> </Row>
</Pager> </Pager>
} }
</TabPage>
<TabPage Text="Page Modules">
@if (pageModules.Count == 0)
{
<br/>
<p>No deleted modules in pages</p>
}
else
{
<Pager Items="@pageModules">
<Header>
<th>Page Name</th>
<th>Control Title</th>
<th>Deletion Audit</th>
<th>&nbsp;</th>
<th>&nbsp;</th>
</Header>
<Row>
<td>@PageState.Pages.Find(item => item.PageId == context.PageId).Name</td>
<td>@context.Title</td>
<td>@context.DeletedBy - @context.DeletedOn</td>
<td><button @onclick="@(() => RestorePageModule(context))" class="btn btn-info" title="Restore">Restore</button></td>
<td><button @onclick="@(() => DeletePageModule(context.PageModuleId, context.ModuleId))" class="btn btn-danger">Delete</button></td>
</Row>
</Pager>
}
</TabPage>
</TabControl>
@code { @code {
public override SecurityAccessLevel SecurityAccessLevel { get { return SecurityAccessLevel.Admin; } } public override SecurityAccessLevel SecurityAccessLevel { get { return SecurityAccessLevel.Admin; } }
List<Page> pageModules = new List<Page>(); bool loadentities { get; set; }
List<Page> pages { get; set; }
List<PageModule> pageModules { get; set; }
protected override async Task OnInitializedAsync()
{
pages = new List<Page>();
pageModules = new List<PageModule>();
loadentities = true;
await LoadEntities();
}
protected override void OnParametersSet() protected override void OnParametersSet()
{ {
pageModules = PageState.Pages.Where(item => item.IsDeleted).ToList(); pages = PageState.Pages.Where(item => item.IsDeleted).ToList();
} }
private async Task Restore(Page Page) private async Task LoadEntities()
{
if (loadentities)
{
pageModules.Clear();
foreach (var module in PageState.Modules.Where(item => item.IsDeleted))
{
var pageModule = await PageModuleService.GetPageModuleAsync(module.PageModuleId);
pageModules.Add(pageModule);
}
loadentities = false;
}
}
private async Task RestorePage(Page Page)
{ {
try try
{ {
@ -52,11 +109,52 @@ else
} }
} }
private async Task Delete(int PageId) private async Task DeletePage(int PageId)
{ {
try try
{ {
var deletedPageModules = PageState.Modules.Where(item => item.PageId == PageId);
await PageService.DeletePageAsync(PageId); await PageService.DeletePageAsync(PageId);
foreach (var module in deletedPageModules)
{
await ModuleService.DeleteModuleAsync(module.ModuleId);
}
NavigationManager.NavigateTo(NavigateUrl("admin/recyclebin", Reload.Site));
}
catch (Exception ex)
{
AddModuleMessage(ex.Message, MessageType.Error);
}
}
private async Task RestorePageModule(PageModule PageModule)
{
try
{
PageModule.IsDeleted = false;
await PageModuleService.UpdatePageModuleAsync(PageModule);
loadentities = true;
await LoadEntities();
NavigationManager.NavigateTo(NavigateUrl("admin/recyclebin", Reload.Site));
}
catch (Exception ex)
{
AddModuleMessage(ex.Message, MessageType.Error);
}
}
private async Task DeletePageModule(int PageModuleId, int ModuleId)
{
try
{
await PageModuleService.DeletePageModuleAsync(PageModuleId);
if (PageState.Modules.Count(item => item.ModuleId == ModuleId) == 1)
{
await ModuleService.DeleteModuleAsync(ModuleId);
}
PageState.Modules.RemoveAt(PageState.Modules.FindIndex(item => item.ModuleId == ModuleId));
loadentities = true;
await LoadEntities();
NavigationManager.NavigateTo(NavigateUrl("admin/recyclebin", Reload.Site)); NavigationManager.NavigateTo(NavigateUrl("admin/recyclebin", Reload.Site));
} }
catch (Exception ex) catch (Exception ex)

View File

@ -149,7 +149,7 @@
string moduletype = "new"; string moduletype = "new";
List<string> categories = new List<string>(); List<string> categories = new List<string>();
List<ModuleDefinition> moduledefinitions; List<ModuleDefinition> moduledefinitions;
List<Page> pages; List<Page> pages = new List<Page>();
string pageid = ""; string pageid = "";
string moduleid = "-"; string moduleid = "-";
List<Module> modules = new List<Module>(); List<Module> modules = new List<Module>();
@ -176,7 +176,7 @@
if (UserSecurity.IsAuthorized(PageState.User, "Edit", PageState.Page.Permissions)) if (UserSecurity.IsAuthorized(PageState.User, "Edit", PageState.Page.Permissions))
{ {
pages = new List<Page>(); pages?.Clear();
foreach (ModuleDefinition moduledefinition in PageState.ModuleDefinitions) foreach (ModuleDefinition moduledefinition in PageState.ModuleDefinitions)
{ {
@ -224,6 +224,7 @@
private void PageChanged(ChangeEventArgs e) private void PageChanged(ChangeEventArgs e)
{ {
pageid = (string)e.Value; pageid = (string)e.Value;
modules?.Clear();
if (pageid != "") if (pageid != "")
{ {
foreach (Module module in PageState.Modules.Where(item => item.PageId == int.Parse(pageid) && !item.IsDeleted)) foreach (Module module in PageState.Modules.Where(item => item.PageId == int.Parse(pageid) && !item.IsDeleted))

View File

@ -10,14 +10,12 @@ namespace Oqtane.Repository
private TenantDBContext db; private TenantDBContext db;
private readonly IPermissionRepository Permissions; private readonly IPermissionRepository Permissions;
private readonly IPageModuleRepository PageModules; private readonly IPageModuleRepository PageModules;
private readonly IModuleRepository ModuleRepository;
public PageRepository(TenantDBContext context, IPermissionRepository Permissions, IPageModuleRepository PageModules, IModuleRepository ModuleRepository) public PageRepository(TenantDBContext context, IPermissionRepository Permissions, IPageModuleRepository PageModules)
{ {
db = context; db = context;
this.Permissions = Permissions; this.Permissions = Permissions;
this.PageModules = PageModules; this.PageModules = PageModules;
this.ModuleRepository = ModuleRepository;
} }
public IEnumerable<Page> GetPages() public IEnumerable<Page> GetPages()

View File

@ -16,6 +16,10 @@ namespace Oqtane.Models
public string ModifiedBy { get; set; } public string ModifiedBy { get; set; }
public DateTime ModifiedOn { get; set; } public DateTime ModifiedOn { get; set; }
[NotMapped]
public string DeletedBy { get; set; }
[NotMapped]
public DateTime? DeletedOn { get; set; }
[NotMapped] [NotMapped]
public bool IsDeleted { get; set; } public bool IsDeleted { get; set; }