...
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
public enum eActionValidation
|
||||
{
|
||||
add,
|
||||
update
|
||||
update,
|
||||
delete
|
||||
}
|
||||
}
|
||||
|
@@ -125,6 +125,11 @@ namespace Back.Controllers
|
||||
if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice))
|
||||
return BadRequest(new List<string> { "این صورتحساب به سازمان ارسال شده"+'\n'+
|
||||
"برای ویرایش ،صورتحساب را ابطال/اصلاح یا برگشت بزنید"});
|
||||
else if (invoice.invoiceType != InvoiceType.Bidding
|
||||
&& invoice.invoiceType != InvoiceType.Sale)
|
||||
{
|
||||
return BadRequest(new List<string> { $"صورتحساب در حالت {invoice.invoiceType.GetEnumDisplayName()} نمی تواند ویرایش شود" });
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -162,6 +167,17 @@ namespace Back.Controllers
|
||||
if (invoice == null)
|
||||
return NotFound();
|
||||
|
||||
|
||||
//----Check TaxPayer
|
||||
if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice))
|
||||
return BadRequest(new List<string> { "این صورتحساب به سازمان ارسال شده"+'\n'+
|
||||
"برای ویرایش ،صورتحساب را ابطال/اصلاح یا برگشت بزنید"});
|
||||
else if (invoice.invoiceType != InvoiceType.Bidding
|
||||
&& invoice.invoiceType != InvoiceType.Sale)
|
||||
{
|
||||
return BadRequest(new List<string> { $"صورتحساب در حالت {invoice.invoiceType.GetEnumDisplayName()} نمی تواند ویرایش شود" });
|
||||
}
|
||||
|
||||
invoice.LastChangeUserID = Convert.ToInt32(UserID);
|
||||
//----Update and sendResult
|
||||
return Ok(await _servInvoice.DeleteInvoice(invoice));
|
||||
|
@@ -63,10 +63,9 @@ namespace Back.Controllers
|
||||
|
||||
|
||||
}
|
||||
[HttpPost("UpdateItem/{invoiceID}")]
|
||||
[HttpPut("UpdateItem/{invoiceID}")]
|
||||
public async Task<ActionResult> UpdateItem([FromRoute] int invoiceID, [FromBody] InvoiceItemDTO model)
|
||||
{
|
||||
//کالا نمی تواند
|
||||
//-----GetUserAndCompany
|
||||
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
|
||||
var UserID = claim.Value;
|
||||
@@ -92,7 +91,7 @@ namespace Back.Controllers
|
||||
invoiceitem.am = model.am;
|
||||
invoiceitem.fee = model.fee;
|
||||
invoiceitem.dis = model.dis;
|
||||
// invoiceitem.CODID = model.CODID;
|
||||
invoiceitem.CODID = model.CODID;
|
||||
|
||||
if (await _servInvoice.UpdateInvoice(invoice))
|
||||
return Ok(await _servInvoiceItem.Update(invoiceitem));
|
||||
@@ -101,5 +100,40 @@ namespace Back.Controllers
|
||||
|
||||
|
||||
}
|
||||
[HttpDelete("DeleteItem/{invoiceID}/{invoiceItemID}")]
|
||||
public async Task<ActionResult> UpdateItem([FromRoute] int invoiceID, [FromRoute] int invoiceItemID)
|
||||
{
|
||||
//-----GetUserAndCompany
|
||||
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
|
||||
var UserID = claim.Value;
|
||||
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
|
||||
|
||||
//-----Validaton
|
||||
var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, invoiceID, new InvoiceItemDTO(), eActionValidation.delete)) ;
|
||||
if (!resultValidationmodel.IsValid)
|
||||
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
|
||||
|
||||
//-----Get invoice
|
||||
Invoice invoice = await _servInvoice.GetInvoiceByInvoiceID(user.RolUsers.First().CompanyID, invoiceID);
|
||||
if (invoice == null)
|
||||
return BadRequest(new List<string> { "invoice notFound..." });
|
||||
|
||||
|
||||
var invoiceitem = await _servInvoiceItem.Getinvoiceitem(user.RolUsers.First().CompanyID, invoiceID, model.ID.Value);
|
||||
if (invoiceitem == null)
|
||||
return BadRequest(new List<string> { "invoice Item notFound..." });
|
||||
|
||||
invoice.LastChangeUserID = Convert.ToInt32(UserID);
|
||||
|
||||
|
||||
|
||||
if (await _servInvoice.UpdateInvoice(invoice))
|
||||
return Ok(await _servInvoiceItem.Delete(invoiceitem));
|
||||
|
||||
else return BadRequest(new List<string> { "خطایی رخ داده" });
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
@@ -19,6 +19,10 @@ namespace Back.Services
|
||||
{
|
||||
return await _invoiceitemRepo.UpdateAsync(item);
|
||||
}
|
||||
public async Task<bool> Delete(InvoiceItem item)
|
||||
{
|
||||
return await _invoiceitemRepo.DeleteAsync(item);
|
||||
}
|
||||
public async Task<bool> Exist(int companyID,int invoiceID,int invoiceitemID)
|
||||
{
|
||||
return await _invoiceitemRepo.Get(w => w.InvoiceID == invoiceID && w.ID == invoiceitemID && w.invoice.CompanyID == companyID).AnyAsync();
|
||||
|
@@ -20,7 +20,7 @@ namespace Back.Services
|
||||
}
|
||||
public async Task<bool> ExistSuccessfulorSendorpendingInvoice(Invoice invoice)
|
||||
{
|
||||
return _repoSentTax.Get(w => /*w.InvoiceType == invoice.invoiceType &&*/ w.InvoiceID == invoice.ID &&
|
||||
return _repoSentTax.Get(w => w.InvoiceType == invoice.invoiceType && w.InvoiceID == invoice.ID &&
|
||||
(w.SentStatus == SentStatus.Successful || w.SentStatus == SentStatus.Send || w.SentStatus == SentStatus.pending)).Any();
|
||||
}
|
||||
public async Task<bool> CheckingTheCompanyKeyInformation(int CompanyID, string UniqeMemory, string PrivateKey, string EconomicCode)
|
||||
|
@@ -23,20 +23,40 @@ namespace Back.Validations
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
|
||||
RuleFor(r => r)
|
||||
.Custom( (model, context) =>
|
||||
{
|
||||
if (model.Item3.CODID != null && model.Item3.CODID > 0)
|
||||
When(m => m.Item4 == eActionValidation.update || m.Item4 == eActionValidation.add, () =>
|
||||
{
|
||||
RuleFor(r => r)
|
||||
.Custom((model, context) =>
|
||||
{
|
||||
if (! servCOD.ExistCodByCompanyID(model.Item3.CODID, model.Item1).Result)
|
||||
context.AddFailure("کالا یافت نشد");
|
||||
}
|
||||
if (model.Item3.CODID != null && model.Item3.CODID > 0)
|
||||
{
|
||||
if (!servCOD.ExistCodByCompanyID(model.Item3.CODID, model.Item1).Result)
|
||||
context.AddFailure("کالا یافت نشد");
|
||||
}
|
||||
|
||||
else context.AddFailure("کالا صحیح نمی باشد");
|
||||
|
||||
});
|
||||
RuleFor(r => r.Item3.am)
|
||||
.NotEmpty().WithMessage("تعداد مشخص نشده")
|
||||
.NotNull().WithMessage("تعداد مشخص نشده");
|
||||
|
||||
RuleFor(r => r.Item3.fee)
|
||||
.NotEmpty().WithMessage("مبلغ واحد مشخص نشده")
|
||||
.NotNull().WithMessage("مبلغ واحد مشخص نشده");
|
||||
|
||||
RuleFor(r => r).Custom(async (model, context) =>
|
||||
{
|
||||
if (model.Item3.dis != null && model.Item3.dis > 0)
|
||||
if (model.Item3.dis > model.Item3.am * model.Item3.fee)
|
||||
context.AddFailure("مبلغ تخفیف نمی تواند از (تعداد * مبلغ واحد) بیشتر باشد");
|
||||
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
else context.AddFailure("کالا صحیح نمی باشد");
|
||||
|
||||
});
|
||||
RuleFor(r => r)
|
||||
.Custom((model, context) =>
|
||||
{
|
||||
@@ -50,6 +70,11 @@ namespace Back.Validations
|
||||
if ( servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice).Result)
|
||||
context.AddFailure("این صورتحساب به سازمان ارسال شده"+'\n'+
|
||||
"برای تغییر ،صورتحساب را ابطال/اصلاح یا برگشت بزنید");
|
||||
else if(invoice.invoiceType!=InvoiceType.Bidding
|
||||
&& invoice.invoiceType != InvoiceType.Sale)
|
||||
{
|
||||
context.AddFailure($"صورتحساب در حالت {invoice.invoiceType.GetEnumDisplayName()} نمی تواند ویرایش شود");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -57,22 +82,7 @@ namespace Back.Validations
|
||||
|
||||
});
|
||||
|
||||
RuleFor(r => r.Item3.am)
|
||||
.NotEmpty().WithMessage("تعداد مشخص نشده")
|
||||
.NotNull().WithMessage("تعداد مشخص نشده");
|
||||
|
||||
RuleFor(r => r.Item3.fee)
|
||||
.NotEmpty().WithMessage("مبلغ واحد مشخص نشده")
|
||||
.NotNull().WithMessage("مبلغ واحد مشخص نشده");
|
||||
|
||||
RuleFor(r => r).Custom(async (model, context) =>
|
||||
{
|
||||
if (model.Item3.dis!=null && model.Item3.dis > 0)
|
||||
if (model.Item3.dis > model.Item3.am * model.Item3.fee)
|
||||
context.AddFailure("مبلغ تخفیف نمی تواند از (تعداد * مبلغ واحد) بیشتر باشد");
|
||||
|
||||
|
||||
});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user