This commit is contained in:
mmrbnjd
2024-05-25 21:30:11 +03:30
parent e4cd267beb
commit 9df826b99e
6 changed files with 97 additions and 32 deletions

View File

@@ -3,6 +3,7 @@
public enum eActionValidation public enum eActionValidation
{ {
add, add,
update update,
delete
} }
} }

View File

@@ -125,6 +125,11 @@ namespace Back.Controllers
if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice)) if (await _servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice))
return BadRequest(new List<string> { "این صورتحساب به سازمان ارسال شده"+'\n'+ 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) if (invoice == null)
return NotFound(); 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); invoice.LastChangeUserID = Convert.ToInt32(UserID);
//----Update and sendResult //----Update and sendResult
return Ok(await _servInvoice.DeleteInvoice(invoice)); return Ok(await _servInvoice.DeleteInvoice(invoice));

View File

@@ -63,10 +63,9 @@ namespace Back.Controllers
} }
[HttpPost("UpdateItem/{invoiceID}")] [HttpPut("UpdateItem/{invoiceID}")]
public async Task<ActionResult> UpdateItem([FromRoute] int invoiceID, [FromBody] InvoiceItemDTO model) public async Task<ActionResult> UpdateItem([FromRoute] int invoiceID, [FromBody] InvoiceItemDTO model)
{ {
//کالا نمی تواند
//-----GetUserAndCompany //-----GetUserAndCompany
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID"); var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value; var UserID = claim.Value;
@@ -92,7 +91,7 @@ namespace Back.Controllers
invoiceitem.am = model.am; invoiceitem.am = model.am;
invoiceitem.fee = model.fee; invoiceitem.fee = model.fee;
invoiceitem.dis = model.dis; invoiceitem.dis = model.dis;
// invoiceitem.CODID = model.CODID; invoiceitem.CODID = model.CODID;
if (await _servInvoice.UpdateInvoice(invoice)) if (await _servInvoice.UpdateInvoice(invoice))
return Ok(await _servInvoiceItem.Update(invoiceitem)); 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> { "خطایی رخ داده" });
}
} }
} }

View File

@@ -19,6 +19,10 @@ namespace Back.Services
{ {
return await _invoiceitemRepo.UpdateAsync(item); 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) 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(); return await _invoiceitemRepo.Get(w => w.InvoiceID == invoiceID && w.ID == invoiceitemID && w.invoice.CompanyID == companyID).AnyAsync();

View File

@@ -20,7 +20,7 @@ namespace Back.Services
} }
public async Task<bool> ExistSuccessfulorSendorpendingInvoice(Invoice invoice) 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(); (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) public async Task<bool> CheckingTheCompanyKeyInformation(int CompanyID, string UniqeMemory, string PrivateKey, string EconomicCode)

View File

@@ -23,20 +23,40 @@ namespace Back.Validations
}); });
}); });
When(m => m.Item4 == eActionValidation.update || m.Item4 == eActionValidation.add, () =>
{
RuleFor(r => r) RuleFor(r => r)
.Custom( (model, context) => .Custom((model, context) =>
{ {
if (model.Item3.CODID != null && model.Item3.CODID > 0) if (model.Item3.CODID != null && model.Item3.CODID > 0)
{ {
if (! servCOD.ExistCodByCompanyID(model.Item3.CODID, model.Item1).Result) if (!servCOD.ExistCodByCompanyID(model.Item3.CODID, model.Item1).Result)
context.AddFailure("کالا یافت نشد"); context.AddFailure("کالا یافت نشد");
} }
else 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("مبلغ تخفیف نمی تواند از (تعداد * مبلغ واحد) بیشتر باشد");
});
});
RuleFor(r => r) RuleFor(r => r)
.Custom((model, context) => .Custom((model, context) =>
{ {
@@ -50,6 +70,11 @@ namespace Back.Validations
if ( servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice).Result) if ( servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice).Result)
context.AddFailure("این صورتحساب به سازمان ارسال شده"+'\n'+ 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("مبلغ تخفیف نمی تواند از (تعداد * مبلغ واحد) بیشتر باشد");
});
} }
} }
} }