Add instruction set extension creation in admin view.

This commit is contained in:
2020-05-28 02:39:51 +01:00
parent b61cf1459b
commit 81e0d4af11
4 changed files with 43 additions and 12 deletions

View File

@@ -32,6 +32,7 @@
@page "/admin/instruction_set_extensions/details/{Id:int}"
@page "/admin/instruction_set_extensions/edit/{Id:int}"
@page "/admin/instruction_set_extensions/create"
@inherits OwningComponentBase<InstructionSetExtensionsService>
@inject IStringLocalizer<InstructionSetExtensionsService> L
@attribute [Authorize(Roles = "UberAdmin, Admin")]

View File

@@ -8,6 +8,7 @@ namespace Marechai.Pages.Admin.Details
{
public partial class InstructionSetExtension
{
bool _creating;
bool _editing;
bool _loaded;
Database.Models.InstructionSetExtension _model;
@@ -21,14 +22,19 @@ namespace Marechai.Pages.Admin.Details
_loaded = true;
if(Id <= 0)
_creating = NavigationManager.ToBaseRelativePath(NavigationManager.Uri).ToLowerInvariant().
StartsWith("admin/instruction_set_extensions/create",
StringComparison.InvariantCulture);
if(Id <= 0 &&
!_creating)
return;
_model = await Service.GetAsync(Id);
_model = _creating ? new Database.Models.InstructionSetExtension() : await Service.GetAsync(Id);
_editing = NavigationManager.ToBaseRelativePath(NavigationManager.Uri).ToLowerInvariant().
StartsWith("admin/instruction_set_extensions/edit/",
StringComparison.InvariantCulture);
_editing = _creating || NavigationManager.ToBaseRelativePath(NavigationManager.Uri).ToLowerInvariant().
StartsWith("admin/instruction_set_extensions/edit/",
StringComparison.InvariantCulture);
StateHasChanged();
}
@@ -42,7 +48,15 @@ namespace Marechai.Pages.Admin.Details
async void OnCancelClicked()
{
_editing = false;
_model = await Service.GetAsync(Id);
if(_creating)
{
NavigationManager.ToBaseRelativePath("admin/instruction_set_extensions");
return;
}
_model = await Service.GetAsync(Id);
StateHasChanged();
}
@@ -53,9 +67,14 @@ namespace Marechai.Pages.Admin.Details
!Service.VerifyUnique(_model.Extension))
return;
_editing = false;
await Service.UpdateAsync(_model);
_model = await Service.GetAsync(Id);
if(_creating)
Id = await Service.CreateAsync(_model);
else
await Service.UpdateAsync(_model);
_editing = false;
_creating = false;
_model = await Service.GetAsync(Id);
StateHasChanged();
}

View File

@@ -42,9 +42,7 @@
return;
}
<p>
<span class="btn btn-primary">
@L["Create new"]
</span>
<a class="btn btn-primary" href="/admin/instruction_set_extensions/create">@L["Create new"]</a>
</p>
<table class="table table-striped">
<thead>

View File

@@ -37,6 +37,19 @@ namespace Marechai.Services
await _context.SaveChangesAsync();
}
public async Task<int> CreateAsync(InstructionSetExtension viewModel)
{
var model = new InstructionSetExtension
{
Extension = viewModel.Extension
};
await _context.InstructionSetExtensions.AddAsync(model);
await _context.SaveChangesAsync();
return model.Id;
}
public async Task DeleteAsync(int id)
{
InstructionSetExtension item = await _context.InstructionSetExtensions.FindAsync(id);