mirror of
https://github.com/claunia/marechai.git
synced 2025-12-16 19:14:25 +00:00
Add instruction set extension creation in admin view.
This commit is contained in:
@@ -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")]
|
||||
|
||||
@@ -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();
|
||||
}
|
||||
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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);
|
||||
|
||||
Reference in New Issue
Block a user