This commit is contained in:
mmrbnjd
2024-08-28 00:29:35 +03:30
parent 21eeb4d11b
commit c118dc0d6b
9 changed files with 338 additions and 27 deletions

View File

@@ -0,0 +1,169 @@
using Back.Common;
using Back.Data.Models;
using Back.Services;
using Back.Validations;
using FluentValidation;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Shared.DTOs;
using System.Net;
using System.Runtime.ConstrainedExecution;
using System.Security.Cryptography;
namespace Back.Controllers
{
[Route("api/[controller]")]
[Authorize]
[ApiController]
public class InvoicePaymentController : ControllerBase
{
private readonly servInvoicePayment _servpay;
private readonly servUser _servUser;
private readonly AUInvoicePayValidation _validation;
private readonly servInvoice _servInvoice;
public InvoicePaymentController(servInvoicePayment servpay, AUInvoicePayValidation validation
, servUser servUser, servInvoice servInvoice)
{
_servpay = servpay;
_validation = validation;
_servUser = servUser;
_servInvoice = servInvoice;
}
[HttpPost("AddPay")]
public async Task<ActionResult<bool>> AddItem([FromBody] InvoiceItemAction<InvoicePaymentDTO> model)
{
//-----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, model.invoiceID, model.item, eActionValidation.add));
//if (!resultValidationmodel.IsValid)
// return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
//-----Get invoice
Invoice invoice = await _servInvoice.GetInvoiceByInvoiceID(user.RolUsers.First().CompanyID, model.invoiceID);
if (invoice == null)
return BadRequest(new List<string> { "invoice notFound..." });
invoice.LastChangeUserID = Convert.ToInt32(UserID);
if (await _servInvoice.UpdateInvoice(invoice))
{
return Ok(await _servpay.Add(new Data.Models.InvoicePayment
{
InvoiceID = model.invoiceID,
acn = model.item.acn,
iinn = model.item.iinn,
PaymentDateTime = model.item.PaymentDateTime.Replace("/", ""),
pcn = model.item.pcn,
pid = model.item.pid,
pmt = model.item.pmt,
pv = model.item.pv,
trmn = model.item.trmn,
trn = model.item.trn,
}));
}
else return BadRequest(new List<string> { "خطایی رخ داده" });
}
[HttpPut("UpdatePay")]
public async Task<ActionResult<bool>> UpdateItem([FromBody] InvoiceItemAction<InvoicePaymentDTO> model)
{
//-----GetUserAndCompany
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
//-----Get invoice
Invoice invoice = await _servInvoice.GetInvoiceByInvoiceID(user.RolUsers.First().CompanyID, model.invoiceID);
if (invoice == null)
return BadRequest(new List<string> { "invoice notFound..." });
//-----Validaton
//var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, model.invoiceID, model.item, eActionValidation.update));
//if (!resultValidationmodel.IsValid)
//{
// if (invoice.invoiceType != InvoiceType.BackFrmSale || (invoice.invoiceType != InvoiceType.BackFrmSale
// && resultValidationmodel.Errors.Count > 1))
// {
// return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
// }
//}
var item = await _servpay.GetInvoicePayByInvoicePayID(user.RolUsers.First().CompanyID, model.invoiceID, model.item.ID.Value);
if (item == null)
return BadRequest(new List<string> { "invoice Pay notFound..." });
invoice.LastChangeUserID = Convert.ToInt32(UserID);
item.acn = model.item.acn;
item.iinn = model.item.iinn;
item.PaymentDateTime = model.item.PaymentDateTime.Replace("/", "");
item.pcn = model.item.pcn;
item.pid = model.item.pid;
item.pmt = model.item.pmt;
item.pv = model.item.pv;
item.trmn = model.item.trmn;
item.trn = model.item.trn;
if (await _servInvoice.UpdateInvoice(invoice))
return Ok(await _servpay.Update(item));
else
return BadRequest(new List<string> { "خطایی رخ داده" });
}
[HttpDelete("DeletePay/{InvoicePayID}")]
public async Task<ActionResult<bool>> DeleteItem(int InvoicePayID)
{
//-----GetUserAndCompany
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
//-----Get invoicePay
var payitem = await _servpay.GetinvoicePay(user.RolUsers.First().CompanyID, InvoicePayID);
if (payitem == null)
return NotFound(new List<string> { "invoice pay notFound..." });
////-----Validaton
//var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, invoiceitem.InvoiceID, new InvoiceItemDTO(), eActionValidation.delete));
//if (!resultValidationmodel.IsValid)
// return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
payitem.invoice.LastChangeUserID = Convert.ToInt32(UserID);
if (await _servInvoice.UpdateInvoice(payitem.invoice))
return Ok(await _servpay.Delete(payitem));
else return BadRequest(new List<string> { "خطایی رخ داده" });
}
}
}

View File

@@ -236,7 +236,7 @@ namespace Back.Controllers
//شماره کدتاژ اظهارنامه گمرکی //شماره کدتاژ اظهارنامه گمرکی
Cdcn = level == 10 ? result.cdcn : null, Cdcn = level == 10 ? result.cdcn : null,
//تاریخ کوتاژ اظهارنامه گمرکی //تاریخ کوتاژ اظهارنامه گمرکی
// Cdcd = level == 10 ? result.cdcd : null, Cdcd = level == 10 ? result.cdcd : null,
//شناسه یکتای ثبت قزارداد فروشنده //شناسه یکتای ثبت قزارداد فروشنده
Crn = (level == 3 || level == 4 || level == 5 || level == 6) && !string.IsNullOrEmpty(result.crn) ? result.crn : null, Crn = (level == 3 || level == 4 || level == 5 || level == 6) && !string.IsNullOrEmpty(result.crn) ? result.crn : null,
//شماره اشتراک/شناسه قبض بهره بردار //شماره اشتراک/شناسه قبض بهره بردار
@@ -358,26 +358,30 @@ namespace Back.Controllers
//Pay //Pay
List<PaymentDto> InvoicePay = new List<PaymentDto>(); List<PaymentDto> InvoicePay = new List<PaymentDto>();
if(level!=10) if (result.setm==1 || result.setm == 3)
foreach (var pitem in result.payments)
{ {
PaymentDto payment = new PaymentDto(); if (level != 10)
payment = new PaymentDto foreach (var pitem in result.payments)
{ {
Iinn=pitem.iinn, PaymentDto payment = new PaymentDto();
Acn=pitem.acn, payment = new PaymentDto
Trmn=pitem.trmn, {
Pmt=pitem.pmt, Iinn = pitem.iinn,
Trn=pitem.trn, Acn = pitem.acn,
Pcn=pitem.pcn, Trmn = pitem.trmn,
Pid=pitem.pid, Pmt = pitem.pmt,
Pdt=pitem.pdt, Trn = pitem.trn,
Pv=pitem.pv, Pcn = pitem.pcn,
Pid = pitem.pid,
}; Pdt = pitem.pdt,
Pv = pitem.pv,
InvoicePay.Add(payment); };
InvoicePay.Add(payment);
}
} }

View File

@@ -71,7 +71,10 @@ namespace Back.Data.Models
//اریخ کوتاژ اظهارنامه گمرکی //اریخ کوتاژ اظهارنامه گمرکی
// Unix Time => from fild CottageDateOfCustomsDeclaration // Unix Time => from fild CottageDateOfCustomsDeclaration
[MaxLength(5)] [MaxLength(5)]
public long? cdcd { get { return string.IsNullOrEmpty(CottageDateOfCustomsDeclaration) ? null : new DateTimeOffset(CottageDateOfCustomsDeclaration.Trim().ToMiladi()).ToUnixTimeMilliseconds(); } } public int? cdcd { get {
return string.IsNullOrEmpty(CottageDateOfCustomsDeclaration) ? null : (int)DateTime.UtcNow.Subtract(CottageDateOfCustomsDeclaration.Trim().ToMiladi()).TotalSeconds;
// return string.IsNullOrEmpty(CottageDateOfCustomsDeclaration) ? null : new DateTimeOffset(CottageDateOfCustomsDeclaration.Trim().ToMiladi()).ToUnixTimeMilliseconds();
} }
//کد پستی خریدار //کد پستی خریدار
[MaxLength(10)] [MaxLength(10)]
public string? bpc { get { return Customer.ZipCode; } } public string? bpc { get { return Customer.ZipCode; } }
@@ -89,7 +92,10 @@ namespace Back.Data.Models
public string? sbc { get { return company?.BranchID; } } public string? sbc { get { return company?.BranchID; } }
//مبلغ پرداختی نقدی //مبلغ پرداختی نقدی
[MaxLength(18)] [MaxLength(18)]
public decimal? cap { get { return tbill- insp- tvam- todam; } } public decimal? cap { get {
return
setm == 1 ? tbill : setm == 2 ? 0 : tbill - insp;
} }
//موضوع صورتحساب //موضوع صورتحساب
[MaxLength(1)] [MaxLength(1)]
public int? ins { get { return (int)invoiceType; } } public int? ins { get { return (int)invoiceType; } }

View File

@@ -67,6 +67,7 @@ builder.Services.AddScoped<servSendMsg>();
builder.Services.AddScoped<servUser>(); builder.Services.AddScoped<servUser>();
builder.Services.AddScoped<servTaxPayer>(); builder.Services.AddScoped<servTaxPayer>();
builder.Services.AddScoped<servCustomer>(); builder.Services.AddScoped<servCustomer>();
builder.Services.AddScoped<servInvoicePayment>();
builder.Services.AddScoped<CompanyRegistrationValidation>(); builder.Services.AddScoped<CompanyRegistrationValidation>();
builder.Services.AddScoped<AddOrCustomerValidation>(); builder.Services.AddScoped<AddOrCustomerValidation>();
builder.Services.AddScoped<AddOrCodValidation>(); builder.Services.AddScoped<AddOrCodValidation>();

View File

@@ -99,7 +99,6 @@ namespace Back.Services
acn = x.acn, acn = x.acn,
iinn = x.acn, iinn = x.acn,
pcn = x.acn, pcn = x.acn,
pdt = x.pdt,
PaymentDateTime = x.PaymentDateTime, PaymentDateTime = x.PaymentDateTime,
pid = x.pid, pid = x.pid,
pmt = x.pmt, pmt = x.pmt,
@@ -233,6 +232,7 @@ namespace Back.Services
.Include(inc => inc.sentTax) .Include(inc => inc.sentTax)
.Include(inc => inc.pattern) .Include(inc => inc.pattern)
.Include(inc => inc.invoice) .Include(inc => inc.invoice)
.Include(inc=>inc.payments)
.FirstOrDefaultAsync(); .FirstOrDefaultAsync();
} }
public async Task<bool> DeleteInvoice(Invoice item) public async Task<bool> DeleteInvoice(Invoice item)

View File

@@ -0,0 +1,45 @@
using Back.Data.Contracts;
using Back.Data.Models;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Hosting;
using Shared.DTOs;
namespace Back.Services
{
public class servInvoicePayment
{
private readonly IAsyncRepository<InvoicePayment> _Repo;
public servInvoicePayment(IAsyncRepository<InvoicePayment> Repo)
{
_Repo = Repo;
}
public async Task<bool> Add(InvoicePayment item)
{
return await _Repo.AddBoolResultAsync(item);
}
public async Task<bool> Update(InvoicePayment item)
{
return await _Repo.UpdateAsync(item);
}
public async Task<bool> Delete(InvoicePayment item)
{
return await _Repo.DeleteAsync(item);
}
public async Task<bool> Exist(int companyID, int invoiceID, int ID)
{
return await _Repo.Get(w => w.InvoiceID == invoiceID && w.ID == ID && w.invoice.CompanyID == companyID).AnyAsync();
}
public async Task<InvoicePayment?> GetinvoicePay(int CompanyID, int ID)
{
return await _Repo
.Get(w => w.ID == ID && w.invoice.CompanyID == CompanyID && !w.invoice.IsDeleted)
.Include(s=>s.invoice)
.FirstOrDefaultAsync();
}
public async Task<InvoicePayment> GetInvoicePayByInvoicePayID (int companyID, int invoiceID, int ID)
{
return await _Repo.Get(w => w.InvoiceID == invoiceID && w.ID == ID && w.invoice.CompanyID == companyID).FirstOrDefaultAsync();
}
}
}

View File

@@ -0,0 +1,89 @@
using Back.Common;
using Back.Services;
using FluentValidation;
using Shared.DTOs;
namespace Back.Validations
{
// companyid invoiceid model
public class AUInvoicePayValidation : AbstractValidator<Tuple<int, int, InvoicePaymentDTO, eActionValidation>>
{
public AUInvoicePayValidation(servInvoice servInvoice, servTaxPayer servTaxPayer, servInvoicePayment servInvoicepay)
{
When(m => m.Item4 == eActionValidation.update, () =>
{
RuleFor(r => r)
.Custom((model, context) =>
{
if (!model.Item3.ID.HasValue)
context.AddFailure("شناسه در حالت ویرایش نمی تواند خالی باشد");
if (!servInvoicepay.Exist(model.Item1, model.Item2, model.Item3.ID.Value).Result)
context.AddFailure("شناسه یافت نشد");
});
});
When(m => m.Item4 == eActionValidation.update || m.Item4 == eActionValidation.add, () =>
{
RuleFor(r => r.Item3).Custom((model, context) =>
{
if (model.pmt.HasValue && model.pmt.Value > 0 && model.pmt.Value < 9)
{
}
else context.AddFailure("روش پرداخت مشخص نشده");
});
//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)
.Custom((model, context) =>
{
if (model.Item2 != null && model.Item2 > 0)
{
var invoice = servInvoice.GetInvoiceByInvoiceID(model.Item1, model.Item2).Result;
if (invoice == null)
context.AddFailure("صورتحساب یافت نشد");
else
{
if (model.Item4 == eActionValidation.update || model.Item4 == eActionValidation.add)
{
var totalpay = invoice.payments.Sum(s => s.pv).GetValueOrDefault() + model.Item3.pv;
if (totalpay > invoice.tbill) context.AddFailure("مجموع مبلغ پرداختی میبایست از مجموع صورتحساب کوچکتر باشد.");
}
if (servTaxPayer.ExistSuccessfulorSendorpendingInvoice(invoice).Result)
context.AddFailure("این صورتحساب به سازمان ارسال شده" + '\n' +
"برای تغییر ،صورتحساب را ابطال/اصلاح یا برگشت بزنید");
else if ((model.Item4 == eActionValidation.add || model.Item4 == eActionValidation.delete)
&& invoice.invoiceType == InvoiceType.BackFrmSale)
context.AddFailure("پرداخت های صورتحساب در وضعیت برگشت از فروش نمی تواند اضافه یا کم شود");
else if (invoice.invoiceType != InvoiceType.Bidding
&& invoice.invoiceType != InvoiceType.Sale && invoice.invoiceType != InvoiceType.Repair)
{
context.AddFailure($"صورتحساب در حالت {invoice.invoiceType.GetEnumDisplayName()} نمی تواند ویرایش شود" + '\n' +
$"فقط در حالت پیش نویس ، فاکتور و اصلاح (که به سازمان ارسال نشده باشد) میتوان سند را ویرایش کرد");
}
}
}
else context.AddFailure("صورتحساب صحیح نمی باشد");
});
}
}
}

View File

@@ -141,12 +141,10 @@ namespace Shared.DTOs
[MaxLength(12)] [MaxLength(12)]
public string? pid { get; set; } public string? pid { get; set; }
//تاریخ و زمان پرداخت //تاریخ و زمان پرداخت
[MaxLength(13)]
public long? pdt { get; set; }
public string? PaymentDateTime { get; set; } public string? PaymentDateTime { get; set; }
//مبلغ پرداختی //مبلغ پرداختی
[MaxLength(18)] [MaxLength(18)]
public decimal? pv { get; set; } public long? pv { get; set; }
} }
//------------------------------ //------------------------------

View File

@@ -23,8 +23,7 @@ builder.Services.AddScoped(sp => new UserAuthenticationDTO()
IsAdmin = false, IsAdmin = false,
Logo = "", Logo = "",
Name = "" Name = ""
} },
,
FullName = "", FullName = "",
Photo="", Photo="",
Token="", Token="",
@@ -37,10 +36,10 @@ builder.Services.AddScoped(sp => new UserAuthenticationDTO()
//builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("http://195.88.208.142:7075/api/") }); //builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("http://195.88.208.142:7075/api/") });
//Home //Home
builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("https://localhost:7075/api/") }); //builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("https://localhost:7075/api/") });
//farzan //farzan
//builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("http://localhost:5271/api/") }); builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri("http://localhost:5271/api/") });
CultureInfo.DefaultThreadCurrentCulture = new CultureInfo("fa-Ir"); CultureInfo.DefaultThreadCurrentCulture = new CultureInfo("fa-Ir");