Files
moadiran/Back/Controllers/InvoiceItemController.cs

199 lines
8.5 KiB
C#
Raw Normal View History

2024-05-25 17:52:40 +03:30
using Back.Common;
using Back.Data.Models;
using Back.Services;
using Back.Validations;
2024-05-28 15:03:08 +03:30
using FluentValidation;
using Microsoft.AspNetCore.Authorization;
2024-05-25 17:52:40 +03:30
using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Shared.DTOs;
using System.Net;
2024-06-18 16:15:17 +03:30
using System.Runtime.ConstrainedExecution;
2024-05-25 17:52:40 +03:30
namespace Back.Controllers
{
[Route("api/[controller]")]
2024-05-28 15:03:08 +03:30
[Authorize]
2024-05-25 17:52:40 +03:30
[ApiController]
public class InvoiceItemController : ControllerBase
{
private readonly servInvoiceItem _servInvoiceItem;
private readonly servUser _servUser;
private readonly AUInvoiceItemValidation _validationInvoiceItem;
private readonly servInvoice _servInvoice;
public InvoiceItemController(servInvoiceItem servInvoiceItem, AUInvoiceItemValidation validationInvoiceItem
, servUser servUser, servInvoice servInvoice)
{
_servInvoiceItem = servInvoiceItem;
_validationInvoiceItem = validationInvoiceItem;
_servUser = servUser;
_servInvoice = servInvoice;
}
2024-05-28 15:03:08 +03:30
[HttpPost("AddItem")]
public async Task<ActionResult<bool>> AddItem([FromBody]InvoiceItemAction<InvoiceItemDTO> model)
2024-05-25 17:52:40 +03:30
{
//-----GetUserAndCompany
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
//-----Validaton
2024-05-28 15:03:08 +03:30
var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, model.invoiceID, model.item, eActionValidation.add));
2024-05-25 17:52:40 +03:30
if (!resultValidationmodel.IsValid)
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
//-----Get invoice
2024-05-28 15:03:08 +03:30
Invoice invoice = await _servInvoice.GetInvoiceByInvoiceID(user.RolUsers.First().CompanyID, model.invoiceID);
2024-05-25 17:52:40 +03:30
if (invoice == null)
return BadRequest(new List<string> { "invoice notFound..." });
2024-12-11 15:33:33 +03:30
if (invoice.invoiceType==InvoiceType.Repair)
{
return BadRequest(new List<string> { "امکان افزودن کالا جدید در صورتحساب اصلاحی وجود ندارد" });
}
if (invoice.invoiceType == InvoiceType.BackFrmSale)
{
return BadRequest(new List<string> { "امکان افزودن کالا جدید در صورتحساب برگشت از فروش وجود ندارد" });
}
2024-05-25 17:52:40 +03:30
invoice.LastChangeUserID = Convert.ToInt32(UserID);
if (await _servInvoice.UpdateInvoice(invoice))
{
return Ok(await _servInvoiceItem.Add(new InvoiceItem
{
2024-05-28 15:03:08 +03:30
am=model.item.am,
fee=model.item.fee,
dis=model.item.dis,
CODID=model.item.CODID,
InvoiceID=model.invoiceID,
2024-05-25 17:52:40 +03:30
}));
}
else return BadRequest(new List<string> { "خطایی رخ داده" });
}
2024-05-28 15:03:08 +03:30
[HttpPut("UpdateItem")]
public async Task<ActionResult<bool>> UpdateItem([FromBody] InvoiceItemAction<InvoiceItemDTO> model)
2024-05-25 17:52:40 +03:30
{
//-----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
2024-05-28 15:03:08 +03:30
Invoice invoice = await _servInvoice.GetInvoiceByInvoiceID(user.RolUsers.First().CompanyID, model.invoiceID);
2024-05-25 17:52:40 +03:30
if (invoice == null)
return BadRequest(new List<string> { "invoice notFound..." });
2024-12-11 15:33:33 +03:30
2024-05-25 17:52:40 +03:30
2024-12-11 15:33:33 +03:30
//-----Validaton
var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, model.invoiceID, model.item, eActionValidation.update));
2024-05-30 15:08:36 +03:30
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());
}
}
2024-05-28 15:03:08 +03:30
var invoiceitem=await _servInvoiceItem.Getinvoiceitem(user.RolUsers.First().CompanyID, model.invoiceID, model.item.ID.Value);
2024-05-25 17:52:40 +03:30
if (invoiceitem == null)
return BadRequest(new List<string> { "invoice Item notFound..." });
2024-12-11 15:33:33 +03:30
if (invoice.invoiceType == InvoiceType.Repair && invoiceitem.CODID != model.item.CODID)
{
return BadRequest(new List<string> { "در صورتحساب اصلاجی نمیتوان کالا را تغییر داد" });
}
if (invoice.invoiceType == InvoiceType.BackFrmSale && invoiceitem.CODID != model.item.CODID)
{
return BadRequest(new List<string> { "در صورتحساب برگشت از فروش نمیتوان کالا را تغییر داد" });
}
if (invoice.invoiceType == InvoiceType.Repair && invoiceitem.fee != model.item.fee)
{
return BadRequest(new List<string> { "در صورتحساب اصلاجی نمیتوان مبلغ واحد را تغییر داد" });
}
if (invoice.invoiceType == InvoiceType.BackFrmSale && invoiceitem.fee != model.item.fee)
{
return BadRequest(new List<string> { "در صورتحساب برگشت از فروش نمیتوان مبلغ واحد را تغییر داد" });
}
2024-05-28 15:03:08 +03:30
if (invoice.invoiceType==InvoiceType.BackFrmSale && invoiceitem.am < model.item.am)
2024-12-11 15:33:33 +03:30
return BadRequest(new List<string> { "در صورتحساب برگشت از فروش تعداد آیتم فقط میتواند کاهشی باشد" });
2024-05-26 13:04:53 +03:30
2024-05-25 17:52:40 +03:30
invoice.LastChangeUserID = Convert.ToInt32(UserID);
2024-05-26 13:04:53 +03:30
if (invoice.invoiceType == InvoiceType.BackFrmSale)
2024-05-28 15:03:08 +03:30
invoiceitem.am = model.item.am;
2024-05-26 13:04:53 +03:30
else
{
2024-05-28 15:03:08 +03:30
invoiceitem.am = model.item.am;
invoiceitem.fee = model.item.fee;
invoiceitem.dis = model.item.dis;
invoiceitem.CODID = model.item.CODID;
2024-05-26 13:04:53 +03:30
}
2024-05-25 17:52:40 +03:30
if (await _servInvoice.UpdateInvoice(invoice))
return Ok(await _servInvoiceItem.Update(invoiceitem));
else return BadRequest(new List<string> { "خطایی رخ داده" });
}
2024-05-28 15:03:08 +03:30
[HttpDelete("DeleteItem/{InvoiceItemID}")]
public async Task<ActionResult<bool>> DeleteItem(int InvoiceItemID)
2024-05-25 21:30:11 +03:30
{
2024-05-28 15:03:08 +03:30
2024-05-25 21:30:11 +03:30
//-----GetUserAndCompany
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
2024-05-28 15:03:08 +03:30
//-----Get invoice
var invoiceitem = await _servInvoiceItem.GetInvoiceItemByInvoiceItemID(user.RolUsers.First().CompanyID, InvoiceItemID);
if (invoiceitem == null)
return NotFound(new List<string> { "invoice Item notFound..." });
2024-05-25 21:30:11 +03:30
//-----Validaton
2024-05-28 15:03:08 +03:30
var resultValidationmodel = await _validationInvoiceItem.ValidateAsync(Tuple.Create(user.RolUsers.First().CompanyID, invoiceitem.InvoiceID.Value, new InvoiceItemDTO(), eActionValidation.delete)) ;
2024-05-25 21:30:11 +03:30
if (!resultValidationmodel.IsValid)
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
2024-12-11 15:33:33 +03:30
if (invoiceitem.invoice.invoiceType == InvoiceType.Repair )
{
return BadRequest(new List<string> { "در صورتحساب اصلاجی نمیتوان کالا را حذف کذد" });
}
if (invoiceitem.invoice.invoiceType == InvoiceType.BackFrmSale)
{
return BadRequest(new List<string> { "در صورتحساب برگشت از فروش نمیتوان کالا را حذف کذد" });
}
2024-05-28 15:03:08 +03:30
invoiceitem.invoice.LastChangeUserID = Convert.ToInt32(UserID);
2024-05-25 21:30:11 +03:30
2024-05-28 15:03:08 +03:30
if (await _servInvoice.UpdateInvoice(invoiceitem.invoice))
2024-05-25 21:30:11 +03:30
return Ok(await _servInvoiceItem.Delete(invoiceitem));
else return BadRequest(new List<string> { "خطایی رخ داده" });
}
2024-06-18 16:15:17 +03:30
2024-05-25 21:30:11 +03:30
2024-05-25 17:52:40 +03:30
}
}