This commit is contained in:
2020-05-10 22:18:41 +00:00
parent c465716f11
commit bd773e85b4

View File

@@ -185,23 +185,26 @@ namespace AyaNova.Biz
// //
internal async Task<bool> DeleteAsync(long id) internal async Task<bool> DeleteAsync(long id)
{ {
WorkOrder dbObject = await ct.WorkOrder.SingleOrDefaultAsync(m => m.Id == id);
ValidateCanDelete(dbObject);
if (HasErrors)
return false;
//collect the child id's to delete
var ItemIds = await ct.WorkOrderItem.Where(m => m.WorkOrderId == id).Select(m => m.Id).ToListAsync();
using (var transaction = await ct.Database.BeginTransactionAsync()) using (var transaction = await ct.Database.BeginTransactionAsync())
{ {
try try
{ {
WorkOrder dbObject = await ct.WorkOrder.SingleOrDefaultAsync(m => m.Id == id);
ValidateCanDelete(dbObject);
if (HasErrors)
return false;
//collect the child id's to delete
var ItemIds = await ct.WorkOrderItem.Where(m => m.WorkOrderId == id).Select(m => m.Id).ToListAsync();
//Delete children //Delete children
foreach (long l in ItemIds) foreach (long ItemId in ItemIds)
{ {
if (!await ItemDeleteAsync(id, transaction)) return false; if (!await ItemDeleteAsync(ItemId, transaction))
return false;
} }
@@ -419,29 +422,28 @@ namespace AyaNova.Biz
// //
internal async Task<bool> ItemDeleteAsync(long id, Microsoft.EntityFrameworkCore.Storage.IDbContextTransaction parentTransaction = null) internal async Task<bool> ItemDeleteAsync(long id, Microsoft.EntityFrameworkCore.Storage.IDbContextTransaction parentTransaction = null)
{ {
WorkOrderItem dbObject = await ct.WorkOrderItem.SingleOrDefaultAsync(m => m.Id == id);
ItemValidateCanDelete(dbObject);
if (HasErrors)
return false;
//collect the child id's to delete
var LaborIds = await ct.WorkOrderItemLabor.Where(m => m.WorkOrderItemId == id).Select(m => m.Id).ToListAsync();
var PartIds = await ct.WorkOrderItemPart.Where(m => m.WorkOrderItemId == id).Select(m => m.Id).ToListAsync();
using (var transaction = parentTransaction ?? await ct.Database.BeginTransactionAsync()) using (var transaction = parentTransaction ?? await ct.Database.BeginTransactionAsync())
{ {
try try
{ {
WorkOrderItem dbObject = await ct.WorkOrderItem.SingleOrDefaultAsync(m => m.Id == id);
ItemValidateCanDelete(dbObject);
if (HasErrors)
return false;
//collect the child id's to delete
var LaborIds = await ct.WorkOrderItemLabor.Where(m => m.WorkOrderItemId == id).Select(m => m.Id).ToListAsync();
var PartIds = await ct.WorkOrderItemPart.Where(m => m.WorkOrderItemId == id).Select(m => m.Id).ToListAsync();
//Delete children //Delete children
foreach (long l in LaborIds) foreach (long ItemId in LaborIds)
{ {
if (!await LaborDeleteAsync(id)) if (!await LaborDeleteAsync(ItemId))
return false; return false;
} }
foreach (long l in PartIds) foreach (long ItemId in PartIds)
{ {
if (!await PartDeleteAsync(id)) if (!await PartDeleteAsync(ItemId))
return false; return false;
} }